/* ==========================================================================
   Основные стили темы УПРиУ
   ========================================================================== */

/* ==========================================================================
   Шапка сайта
   ========================================================================== */

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

@media (max-width: 576px) {
    .about-management-section {
        background: #f1f5f9;
    }

    .about-management-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .about-management-section .breadcrumbs {
        margin-bottom: 28px;
    }

    .about-management-section .about-page-layout {
        display: flex;
        flex-direction: column;
        gap: 42px;
        padding-bottom: 80px;
    }

    .about-management-section .section-side-nav {
        position: static;
        display: flex;
        flex-direction: column;
        gap: 10px;
        width: 100%;
    }

    .about-management-section .side-pill {
        width: 100%;
        min-height: 44px;
        height: 44px;
        padding: 12px 24px;
        border-radius: 50px;
        background: #fff;
        box-shadow: none;
        color: #2c3e50;
        font-family: var(--font-secondary);
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
        letter-spacing: -0.02em;
    }

    .about-management-section .side-pill.is-active {
        background: #2fb4be;
        color: #fff;
    }

    .about-management-section .inner-page-content {
        width: 100%;
        max-width: none;
    }

    .about-management-section .page-title,
    .about-management-section .content-section-title {
        margin: 0 0 24px;
        font-family: var(--font-primary);
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #0a3d62;
    }

    .about-management-section .section-copy {
        max-width: none;
        font-family: var(--font-secondary);
        font-size: 14px;
        font-weight: 400;
        line-height: 22px;
        letter-spacing: -0.02em;
        color: #2c3e50;
    }

    .about-management-section .section-copy p {
        margin: 0 0 14px;
    }

    .about-management-section .section-copy p:last-child {
        margin-bottom: 0;
    }

    .about-management-section .content-section-block {
        margin-top: 60px;
    }

    .about-management-section .info-card-grid,
    .about-management-section .info-card-grid-2x2 {
        display: grid;
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .about-management-section .info-card {
        width: 100%;
        min-height: 302px;
        height: 302px;
        padding: 30px;
    }

    .about-management-section .info-card-number {
        left: 30px;
        top: 30px;
        width: 60px;
        height: 60px;
        font-size: 18px;
        line-height: 28px;
    }

    .about-management-section .info-card h3 {
        left: 30px;
        top: 128px;
        max-width: 265px;
        font-size: 18px;
        font-weight: 600;
        line-height: 24px;
        letter-spacing: -0.02em;
    }

    .about-management-section .info-card a {
        left: 30px;
        top: auto;
        bottom: 30px;
        gap: 12px;
        font-size: 16px;
        line-height: 20px;
    }

    .about-management-section .info-card a::after {
        width: 6px;
        height: 12px;
    }

    .about-management-section .info-card-art {
        top: 51px;
        right: -59px;
        width: 200px;
        height: 200px;
    }

    .about-management-section .info-card.is-accent .info-card-art img {
        opacity: 0.2;
    }

    .about-management-section .info-card.is-dark .info-card-art img,
    .about-management-section .info-card.is-slate .info-card-art img {
        opacity: 0.1;
    }

    .about-management-section .doc-card-grid,
    .about-management-section .doc-card-grid-2 {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
        justify-content: stretch;
    }

    .about-management-section .doc-link-card {
        width: 100%;
        min-height: 92px;
        height: 92px;
        gap: 12px;
        padding: 24px 14px;
        font-size: 10px;
        line-height: 12px;
    }

    .about-management-section .doc-icon {
        width: 30px;
        height: 30px;
        flex-basis: 30px;
    }

    .about-management-section .doc-icon img {
        width: 30px;
        height: 30px;
    }

    .about-management-section .legal-info-list {
        gap: 10px;
        width: 100%;
        max-width: 100%;
        padding-right: 0;
        padding-left: 0;
        font-family: var(--font-secondary);
        font-size: 14px;
        font-weight: 600;
        line-height: 24px;
        letter-spacing: -0.02em;
        color: #2c3e50;
        overflow-wrap: anywhere;
    }

    .about-management-section .legal-info-item {
        width: 100%;
        max-width: 100%;
        padding: 0;
    }

    .about-management-section .legal-info-list ul,
    .about-management-section .legal-info-item ul {
        margin: 0;
        padding-left: 18px;
    }

    .about-management-section .legal-info-list li,
    .about-management-section .legal-info-item li {
        padding-left: 0;
    }

    .about-management-section .legal-info-list li::marker,
    .about-management-section .legal-info-item li::marker {
        font-size: 0.7em;
    }

    .about-management-section .contact-info-row {
        display: flex;
        flex-direction: column;
        gap: 24px;
        margin-bottom: 30px;
    }

    .about-management-section .contact-simple-list {
        gap: 16px;
        font-size: 16px;
        line-height: 24px;
    }

    .about-management-section .contact-simple-item {
        gap: 8px;
    }

    .about-management-section .contact-simple-item img {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    .about-management-section .contact-section-button {
        width: 100%;
        min-height: 60px;
        height: 60px;
        margin-top: 0;
        padding: 18px 40px;
        font-size: 16px;
        line-height: 24px;
    }

    .about-management-section .map-placeholder,
    .about-management-section .map-placeholder iframe,
    .about-management-section .map-placeholder-image {
        width: 100%;
        height: auto;
        min-height: 0;
        aspect-ratio: 1 / 1;
    }
}

.header-top {
    padding: 32px 0;
    background-color: var(--white);
}

.header-top-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 36px;
}

.header-logo {
    flex-shrink: 0;
}

.site-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
}

.logo-full {
    width: 254px;
    height: 92px;
    flex: 0 0 254px;
}

.logo-full img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.logo-icon {
    width: 66px;
    height: 92px;
}

.logo-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.logo-text {
    display: flex;
    flex-direction: column;
}

.logo-subtitle {
    font-family: var(--font-secondary);
    font-size: 12px;
    line-height: 120%;
    color: var(--text-color);
}

.logo-title {
    font-family: var(--font-primary);
    font-size: 14.37px;
    line-height: 18px;
    font-weight: 700;
    color: var(--primary-color);
    text-transform: uppercase;
    letter-spacing: -0.02em;
}

.header-search {
    flex: 1;
    max-width: 312px;
}

.search-form {
    display: flex;
    align-items: center;
    background-color: var(--white);
    border-radius: 50px;
    padding: 8px 20px;
}

.search-field {
    flex: 1;
    border: none;
    outline: none;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 20px;
    color: var(--text-color);
    background: transparent;
}

.search-field::placeholder {
    color: var(--text-color);
}

.search-submit {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.search-submit svg {
    width: 28px;
    height: 28px;
}

.header-contacts {
    display: flex;
    align-items: center;
    gap: 36px;
}

.header-contact-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

.header-contact-item svg {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
}

.header-contact-icon {
    display: block;
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
    object-fit: contain;
}

.header-contact-item a,
.header-contact-item span {
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: var(--text-color);
    text-decoration: none;
}

.header-contact-item a:hover {
    color: var(--secondary-color);
}

.mobile-menu-toggle {
    display: none;
    flex-direction: column;
    justify-content: space-between;
    width: 24px;
    height: 20px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

.mobile-menu-toggle span {
    display: block;
    width: 100%;
    height: 2.22px;
    background-color: var(--primary-color);
    border-radius: 2px;
}

/* Навигация */
.main-navigation {
    background-color: var(--white);
    border-top: 1px solid rgba(166, 178, 193, 0.3);
}

.main-navigation ul {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 36px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.main-navigation li {
    position: relative;
}

.main-navigation a {
    display: block;
    padding: 20px 0;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 22px;
    color: var(--text-color);
    text-decoration: none;
    transition: color 0.3s ease;
}

.main-navigation a:hover {
    color: var(--secondary-color);
}

.main-navigation .current-menu-item > a {
    color: var(--secondary-color);
}

/* Подменю */
.main-navigation .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    background-color: var(--white);
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    padding: 10px 0;
    z-index: 100;
}

.main-navigation li:hover > .sub-menu {
    display: block;
}

.main-navigation .sub-menu a {
    padding: 10px 20px;
    font-size: 14px;
}

.fullscreen-menu-open {
    overflow: hidden;
    background: #0a3d62;
}

.fullscreen-menu {
    position: fixed;
    inset: 0;
    z-index: 5000;
    display: none;
    overflow-y: auto;
    background: #0a3d62;
    color: #ffffff;
}

.fullscreen-menu.is-open {
    display: block;
}

.fullscreen-menu__inner {
    position: relative;
    width: min(1310px, calc(100% - 48px));
    min-height: 952px;
    margin: 0 auto;
    padding: 32px 0 80px;
}

.fullscreen-menu__top {
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    min-height: 124px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.fullscreen-menu__logo {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    width: 254px;
    height: 92px;
    margin-top: 14px;
    text-decoration: none;
}

.fullscreen-menu__logo-icon {
    width: 66px;
    height: 92px;
    flex: 0 0 66px;
}

.fullscreen-menu__logo-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.fullscreen-menu__logo-text {
    display: flex;
    flex-direction: column;
}

.fullscreen-menu__logo-subtitle {
    width: 145px;
    margin-bottom: 8px;
    font-family: var(--font-secondary);
    font-size: 12px;
    line-height: 120%;
    letter-spacing: -0.02em;
    color: #ffffff;
}

.fullscreen-menu__logo-title {
    width: 170px;
    font-family: var(--font-primary);
    font-size: 14.3662px;
    line-height: 18px;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #ffffff;
}

.fullscreen-menu__close {
    position: relative;
    width: 24px;
    height: 24px;
    margin-top: 37px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.fullscreen-menu__close span {
    position: absolute;
    left: 0;
    top: 11px;
    width: 24px;
    height: 2px;
    background: #ffffff;
    transform-origin: center;
}

.fullscreen-menu__close span:first-child {
    transform: rotate(-45deg);
}

.fullscreen-menu__close span:last-child {
    transform: rotate(45deg);
}

.fullscreen-menu__columns {
    display: grid;
    grid-template-columns: 202px 231px 232px 225px;
    justify-content: space-between;
    gap: 72px;
    padding-top: 72px;
    min-height: 513px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.fullscreen-menu__column {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.fullscreen-menu__column-main {
    gap: 28px;
}

.fullscreen-menu__heading {
    font-family: var(--font-primary);
    font-size: 22px;
    line-height: 28px;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #ffffff;
    text-decoration: none;
}

.fullscreen-menu__heading:hover,
.fullscreen-menu__subnav a:hover,
.fullscreen-menu__contact-value:hover {
    color: #2fb4be;
}

.fullscreen-menu__subnav {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.fullscreen-menu__subnav a {
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 20px;
    font-weight: 400;
    letter-spacing: -0.02em;
    color: #ffffff;
    text-decoration: none;
}

.fullscreen-menu__contacts {
    display: grid;
    grid-template-columns: 286px 194px 169px 196px;
    justify-content: space-between;
    gap: 72px;
    padding-top: 88px;
}

.fullscreen-menu__contact {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.fullscreen-menu__contact-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 28px;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 22px;
    letter-spacing: -0.02em;
    color: #a6b2c1;
}

.fullscreen-menu__contact-label svg,
.fullscreen-menu__contact-icon {
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
}

.fullscreen-menu__contact-icon {
    display: block;
    object-fit: contain;
}

.fullscreen-menu__contact-value {
    font-family: var(--font-secondary);
    font-size: 20px;
    line-height: 27px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: #ffffff;
    text-decoration: none;
}

@media (max-width: 1279px) {
    .fullscreen-menu__inner {
        min-height: 100vh;
    }

    .fullscreen-menu__columns {
        grid-template-columns: repeat(2, minmax(220px, 1fr));
        justify-content: stretch;
    }

    .fullscreen-menu__contacts {
        grid-template-columns: repeat(2, minmax(220px, 1fr));
        justify-content: stretch;
    }
}

@media (max-width: 991px) {
    .fullscreen-menu {
        display: none !important;
    }
}

@media (max-width: 768px) {
    .fullscreen-menu__inner {
        width: calc(100% - 32px);
        padding: 24px 0 48px;
    }

    .fullscreen-menu__top {
        min-height: 112px;
    }

    .fullscreen-menu__close {
        margin-top: 28px;
    }

    .fullscreen-menu__columns {
        grid-template-columns: 1fr;
        gap: 44px;
        padding-top: 48px;
        padding-bottom: 48px;
    }

    .fullscreen-menu__contacts {
        grid-template-columns: 1fr;
        gap: 28px;
        padding-top: 48px;
    }

    .fullscreen-menu__column,
    .fullscreen-menu__subnav {
        gap: 20px;
    }

    .fullscreen-menu__heading {
        font-size: 20px;
        line-height: 26px;
    }
}

/* ==========================================================================
   Хлебные крошки
   ========================================================================== */

.breadcrumbs {
    padding: 20px 0;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 22px;
    color: var(--text-light);
}

.breadcrumbs a {
    color: var(--text-light);
    text-decoration: none;
}

.breadcrumbs a:hover {
    color: var(--secondary-color);
}

/* ==========================================================================
   Заголовок страницы
   ========================================================================== */

.page-header {
    padding: 40px 0;
    background-color: var(--background-color);
}

.page-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin: 0;
}

/* ==========================================================================
   Hero секция
   ========================================================================== */

.hero-section {
    position: relative;
    height: 952px;
    overflow: hidden;
}

.hero-slider {
    position: relative;
    width: 100%;
    height: 100%;
}

.hero-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s ease, visibility 0.5s ease;
}

.hero-slide.active {
    opacity: 1;
    visibility: visible;
}

.hero-slide-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 1167px;
    height: 788px;
    overflow: hidden;
}

.hero-bg-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.hero-bg-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.14), rgba(0, 0, 0, 0.14)), var(--accent-color);
}

.hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.14), rgba(0, 0, 0, 0.14));
}

.hero-content {
    position: relative;
    z-index: 10;
    height: 100%;
    display: flex;
    align-items: center;
    padding-left: 120px;
}

.hero-title {
    font-size: 52px;
    line-height: 63px;
    color: var(--white);
    max-width: 780px;
    margin-bottom: 20px;
}

.hero-subtitle {
    font-size: 20px;
    line-height: 32px;
    color: var(--white);
    margin-bottom: 30px;
}

.hero-meta {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-bottom: 30px;
}

.hero-date,
.hero-time {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-secondary);
    font-size: 18px;
    line-height: 32px;
    color: var(--white);
}

.hero-date svg,
.hero-time svg {
    width: 24px;
    height: 24px;
}

.hero-slider-controls {
    position: absolute;
    bottom: 60px;
    left: 120px;
    z-index: 20;
    display: flex;
    align-items: center;
    gap: 20px;
}

.hero-slider-dots {
    display: flex;
    align-items: center;
    gap: 10px;
}

.hero-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.5);
    border: none;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.hero-dot.active {
    background-color: var(--white);
}

.hero-slider-arrows {
    display: flex;
    align-items: center;
    gap: 10px;
}

.hero-arrow {
    width: 68px;
    height: 68px;
    border-radius: 50%;
    background-color: var(--white);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.3s ease;
}

.hero-arrow:hover {
    background-color: var(--secondary-color);
}

.hero-arrow svg {
    width: 12px;
    height: 19px;
}

.hero-sidebar {
    position: absolute;
    top: 164px;
    right: 0;
    z-index: 10;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.hero-sidebar-card {
    width: 743px;
    height: 188px;
    background-color: #ffffff;
    display: flex;
    align-items: center;
    padding: 0 80px;
    gap: 40px;
}

.hero-sidebar-icon {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
}

.hero-sidebar-icon svg {
    width: 100%;
    height: 100%;
}

.hero-sidebar-title {
    font-family: var(--font-primary);
    font-size: 22px;
    line-height: 28px;
    font-weight: 600;
    color: var(--text-color);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    flex: 1;
}

.hero-sidebar-link {
    font-family: var(--font-secondary);
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    color: var(--secondary-color);
    text-decoration: none;
}

.hero-sidebar-link:hover {
    color: var(--primary-color);
}

/* ==========================================================================
   Быстрые ссылки
   ========================================================================== */

.quick-links-section {
    padding: 80px 0;
    background-color: var(--background-color);
}

.quick-links-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 34px;
}

.quick-link-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 30px;
    background-color: var(--white);
    border-radius: var(--border-radius-sm);
    text-decoration: none;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.quick-link-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 54px -20px rgba(10, 61, 98, 0.3);
}

.quick-link-icon {
    width: 80px;
    height: 80px;
    margin-bottom: 20px;
}

.quick-link-icon svg {
    width: 100%;
    height: 100%;
}

.quick-link-title {
    font-family: var(--font-primary);
    font-size: 22px;
    line-height: 28px;
    font-weight: 600;
    color: var(--text-color);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    text-align: center;
}

/* ==========================================================================
   Секция новостей
   ========================================================================== */

.news-section {
    padding: 80px 0;
    background-color: var(--background-color);
}

.section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 40px;
}

.section-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin: 0;
}

.section-link {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-secondary);
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    color: var(--primary-color);
    text-decoration: none;
}

.section-link:hover {
    color: var(--secondary-color);
}

.section-link svg {
    width: 8px;
    height: 16px;
}

.news-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 34px;
}

.news-card {
    background-color: var(--white);
    border-radius: var(--border-radius-sm);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.news-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 54px -20px rgba(10, 61, 98, 0.3);
}

.news-card-image {
    position: relative;
    width: 100%;
    height: 224px;
    overflow: hidden;
}

.news-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.news-image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--background-color);
}

.news-image-placeholder svg {
    width: 64px;
    height: 64px;
}

.news-card-body {
    padding: 30px;
}

.news-card-title {
    font-family: var(--font-secondary);
    font-size: 20px;
    line-height: 28px;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 15px;
}

.news-card-title a {
    color: inherit;
    text-decoration: none;
}

.news-card-title a:hover {
    color: var(--secondary-color);
}

.news-card-meta {
    display: flex;
    align-items: center;
    gap: 16px;
}

.news-card-date {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 22px;
    color: var(--text-light);
}

.news-card-date svg {
    width: 28px;
    height: 28px;
}

.news-card-category {
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: var(--secondary-color);
}

/* ==========================================================================
   Секция направлений деятельности
   ========================================================================== */

.directions-section {
    padding: 80px 0;
    background-color: var(--background-color);
}

.directions-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 34px;
}

.direction-card {
    position: relative;
    width: 414px;
    height: 540px;
    background-color: var(--white);
    border-radius: var(--border-radius-sm);
    padding: 50px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.direction-card-accent {
    background-color: var(--secondary-color);
}

.direction-card-dark {
    background-color: var(--primary-color);
}

.direction-number {
    position: absolute;
    top: 50px;
    left: 50px;
    width: 68px;
    height: 68px;
    border-radius: 50%;
    background-color: var(--secondary-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-primary);
    font-size: 22px;
    line-height: 28px;
    font-weight: 600;
    color: var(--white);
    text-transform: uppercase;
    letter-spacing: -0.02em;
}

.direction-card-accent .direction-number,
.direction-card-dark .direction-number {
    background-color: var(--white);
    color: var(--secondary-color);
}

.direction-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 240px;
    height: 240px;
    opacity: 0.2;
}

.direction-icon svg {
    width: 100%;
    height: 100%;
}

.direction-title {
    font-family: var(--font-primary);
    font-size: 22px;
    line-height: 28px;
    font-weight: 600;
    color: var(--text-color);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    margin-top: auto;
    margin-bottom: 20px;
}

.direction-card-accent .direction-title,
.direction-card-dark .direction-title {
    color: var(--white);
}

.direction-link {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-secondary);
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    color: var(--secondary-color);
    text-decoration: none;
}

.direction-card-accent .direction-link,
.direction-card-dark .direction-link {
    color: var(--white);
}

.direction-link:hover {
    color: var(--primary-color);
}

.direction-card-accent .direction-link:hover,
.direction-card-dark .direction-link:hover {
    color: var(--white);
    opacity: 0.8;
}

.direction-link svg {
    width: 8px;
    height: 16px;
}

/* ==========================================================================
   Секция партнеров
   ========================================================================== */

.partners-section {
    padding: 80px 0;
    background-color: var(--background-color);
}

.partners-tabs {
    display: flex;
    align-items: center;
    gap: 32px;
}

.partner-tab {
    font-family: var(--font-secondary);
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    color: var(--text-light);
    background: none;
    border: none;
    cursor: pointer;
    text-align: right;
    padding: 0;
    transition: color 0.3s ease;
}

.partner-tab:hover,
.partner-tab.active {
    color: var(--primary-color);
}

.partners-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 34px;
}

.partner-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 30px;
    background-color: var(--white);
    border-radius: var(--border-radius-sm);
    text-decoration: none;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.partner-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 54px -20px rgba(10, 61, 98, 0.3);
}

.partner-logo {
    max-width: 100%;
    max-height: 60px;
    object-fit: contain;
    margin-bottom: 20px;
}

.partner-logo-placeholder {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: var(--secondary-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-primary);
    font-size: 20px;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 20px;
}

.partner-name {
    font-family: var(--font-secondary);
    font-size: 18px;
    line-height: 24px;
    font-weight: 600;
    color: var(--text-color);
    text-align: center;
}

/* ==========================================================================
   Форма обратной связи
   ========================================================================== */

.contact-form-section {
    padding: 80px 0;
    background-color: rgba(10, 61, 98, 0.04);
}

.contact-form-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.contact-form-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin-bottom: 20px;
}

.contact-form-description {
    font-size: 20px;
    line-height: 32px;
    color: var(--text-color);
    margin-bottom: 30px;
}

.contact-form-image {
    max-width: 100%;
}

.contact-form-image img {
    width: 100%;
    height: auto;
}

.contact-form-container {
    background-color: var(--white);
    border-radius: var(--border-radius-sm);
    padding: 40px;
}

.contact-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.form-group {
    margin-bottom: 0;
}

.form-control {
    width: 100%;
    padding: 18px 32px;
    font-family: var(--font-secondary);
    font-size: 18px;
    line-height: 32px;
    color: var(--text-color);
    background-color: var(--white);
    border: none;
    border-radius: var(--border-radius);
    outline: none;
    transition: box-shadow 0.3s ease;
}

.form-control:focus {
    box-shadow: 0 0 0 3px rgba(47, 180, 190, 0.3);
}

.form-control::placeholder {
    color: var(--text-color);
}

textarea.form-control {
    min-height: 200px;
    resize: vertical;
    border-radius: var(--border-radius-sm);
}

.form-actions {
    display: flex;
    align-items: center;
    gap: 20px;
}

.form-disclaimer {
    font-size: 16px;
    line-height: 22px;
    color: var(--text-light);
    max-width: 281px;
}

/* ==========================================================================
   Секция рассылки
   ========================================================================== */

.newsletter-section {
    position: relative;
    padding: 140px 0;
    background-color: var(--primary-color);
    overflow: hidden;
}

.newsletter-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.newsletter-bg::after {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    width: 522px;
    height: 522px;
    background: url("../images/logohomepodpiskabanner.png") right center / auto 522px no-repeat;
}

.newsletter-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, rgba(10, 61, 98, 0.9) 0%, rgba(10, 61, 98, 0.7) 100%);
}

.newsletter-content {
    position: relative;
    z-index: 10;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.newsletter-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--white);
    margin-bottom: 20px;
}

.newsletter-description {
    font-size: 20px;
    line-height: 28px;
    color: var(--white);
}

.newsletter-form-container {
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: var(--border-radius-sm);
    padding: 40px;
}

.newsletter-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.newsletter-form .form-control {
    background-color: var(--background-color);
}

.newsletter-disclaimer {
    font-size: 16px;
    line-height: 22px;
    color: rgba(255, 255, 255, 0.7);
    text-align: center;
}

/* ==========================================================================
   Секция госуслуг
   ========================================================================== */

.gosuslugi-section {
    padding: 140px 0;
    background-color: var(--primary-color);
    position: relative;
    overflow: hidden;
}

.gosuslugi-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.gosuslugi-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--white);
    margin-bottom: 20px;
}

.gosuslugi-description {
    font-size: 20px;
    line-height: 28px;
    color: var(--white);
    margin-bottom: 30px;
}

.gosuslugi-image {
    max-width: 100%;
}

.gosuslugi-image img {
    width: 100%;
    height: auto;
}

/* ==========================================================================
   Подвал сайта
   ========================================================================== */

.site-footer {
    background-color: var(--background-color);
}

.footer-main {
    padding: 80px 0;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 42px;
}

.footer-about {
    max-width: 286px;
}

.footer-logo {
    margin-bottom: 20px;
}

.footer-description {
    font-size: 16px;
    line-height: 22px;
    color: var(--text-color);
}

.footer-nav h4,
.footer-contacts h4,
.footer-app h4 {
    font-family: var(--font-primary);
    font-size: 22px;
    line-height: 28px;
    font-weight: 700;
    color: var(--text-color);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    margin-bottom: 20px;
}

.footer-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.footer-nav li {
    margin-bottom: 15px;
}

.footer-nav a {
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 22px;
    color: var(--text-color);
    text-decoration: none;
}

.footer-nav a:hover {
    color: var(--secondary-color);
}

.footer-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 20px;
}

.footer-contact-item svg,
.footer-contact-item .contact-ui-icon {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    margin-top: 2px;
}

.footer-contact-item span,
.footer-contact-item a {
    font-family: var(--font-secondary);
    font-size: 20px;
    line-height: 27px;
    font-weight: 600;
    color: var(--text-color);
    text-decoration: none;
}

.footer-contact-item a:hover {
    color: var(--secondary-color);
}

.footer-contact-phones {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.footer-contact-phones a {
    font-size: 20px;
    line-height: 27px;
}

.app-screenshot {
    width: 229px;
    height: 450px;
    border-radius: 4px;
    overflow: hidden;
}

.app-screenshot img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.footer-bottom {
    padding: 30px 0;
    border-top: 1px solid rgba(166, 178, 193, 0.3);
}

.footer-bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.copyright {
    font-size: 16px;
    line-height: 22px;
    color: var(--text-color);
    margin: 0;
}

.copyright a {
    color: var(--text-color);
    text-decoration: none;
}

.copyright a:hover {
    color: var(--secondary-color);
}

/* ==========================================================================
   Блог список
   ========================================================================== */

.blog-list-section {
    padding: 0 0 140px;
    background-color: var(--background-color);
}

.blog-list-header {
    margin-bottom: 56px;
}

.blog-list-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin: 0 0 36px;
}

.blog-list-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
}

.blog-list-filters {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.filter-group {
    position: relative;
}

.filter-group .form-control,
.news-filter-trigger {
    width: 210px;
    min-width: 210px;
    min-height: 68px;
    padding: 18px 50px 18px 32px;
    border: 0;
    border-radius: 999px;
    background: #ffffff;
    color: #2c3e50;
    font-size: 16px;
    line-height: 32px;
    letter-spacing: -0.02em;
    box-shadow: inset 0 0 0 1px rgba(13, 70, 114, 0.04);
}

.filter-group .form-control {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%232C3E50' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 20px center;
}

.news-filter-dropdown {
    position: relative;
}

.news-filter-dropdown[open] {
    z-index: 20;
}

.news-filter-dropdown summary {
    list-style: none;
}

.news-filter-dropdown summary::-webkit-details-marker {
    display: none;
}

.news-filter-trigger {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-right: 58px;
    cursor: pointer;
    user-select: none;
}

.news-filter-trigger::after {
    content: "";
    position: absolute;
    right: 32px;
    top: 50%;
    width: 12px;
    height: 8px;
    transform: translateY(-50%);
    background: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%232C3E50' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
    transition: transform 0.2s ease;
}

.news-filter-dropdown[open] .news-filter-trigger::after {
    transform: translateY(-50%) rotate(180deg);
}

.news-filter-category .news-filter-trigger,
.news-filter-period .news-filter-trigger {
    width: 302px;
    min-width: 302px;
}

.news-filter-period .news-filter-trigger {
    width: 360px;
    min-width: 360px;
}

.news-filter-trigger-label {
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    font-size: 16px;
    line-height: 20px;
}

.news-filter-panel {
    position: absolute;
    top: calc(100% + 12px);
    left: 0;
    width: 360px;
    padding: 20px;
    border-radius: 28px;
    background: #ffffff;
    box-shadow: 0 24px 60px rgba(10, 61, 98, 0.16);
}

.news-category-panel {
    width: 302px;
    padding: 18px 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.news-category-link {
    display: flex;
    align-items: center;
    min-height: 48px;
    padding: 10px 20px;
    color: #2c3e50;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 20px;
    font-weight: 400;
    letter-spacing: -0.02em;
}

.news-category-link:hover,
.news-category-link.is-active {
    background: #f1f5f9;
    color: #0a3d62;
}

.news-filter-panel-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.news-filter-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
    color: #2c3e50;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 20px;
    font-weight: 400;
    letter-spacing: -0.02em;
}

.news-filter-field .form-control {
    width: 100%;
    min-width: 0;
    padding-right: 32px;
    background-image: none;
}

.news-filter-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 18px;
}

.news-filter-apply {
    min-width: 184px;
    min-height: 58px;
    padding: 14px 32px;
    font-family: var(--font-secondary);
    font-size: 18px;
    line-height: 24px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.news-filter-reset {
    color: #2fb4be;
    font-size: 14px;
    line-height: 20px;
    font-weight: 700;
}

.news-filter-archive {
    margin-left: auto;
}

.news-archive-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 200px;
    min-height: 68px;
    padding: 18px 32px;
    border-radius: 999px;
    cursor: pointer;
    list-style: none;
}

.news-archive-panel {
    right: 0;
    left: auto;
    width: 220px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.news-archive-link {
    display: flex;
    align-items: center;
    min-height: 46px;
    padding: 12px 16px;
    border-radius: 16px;
    color: #2c3e50;
    font-size: 16px;
    line-height: 20px;
    font-weight: 600;
}

.news-archive-link:hover,
.news-archive-link.is-active {
    background: #f1f5f9;
    color: #0a3d62;
}

.blog-list-grid {
    display: grid;
    grid-template-columns: repeat(4, 302px);
    gap: 34px;
    justify-content: space-between;
    margin-bottom: 68px;
}

.blog-list-grid .news-card {
    width: 302px;
    height: 464px;
    min-height: 464px;
    max-height: 464px;
    border-radius: 0;
    box-shadow: none;
    background: #ffffff;
}

.blog-list-grid .news-card-image,
.blog-list-grid .news-card-image a,
.blog-list-grid .news-image,
.blog-list-grid .news-image-placeholder {
    width: 302px;
    height: 224px;
}

.blog-list-grid .news-card-body {
    height: 240px;
}

/* ==========================================================================
   Архив
   ========================================================================== */

.archive-list-section {
    padding: 113px 0 140px;
    background-color: var(--background-color);
}

.archive-list-header {
    margin-bottom: 56px;
}

.archive-list-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin-bottom: 20px;
}

.archive-list-description {
    font-size: 20px;
    line-height: 32px;
    color: var(--text-color);
}

.archive-list-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 34px;
    justify-content: space-between;
}

/* ==========================================================================
   Одиночная запись
   ========================================================================== */

.single-post-section {
    padding: 113px 0 140px;
    background-color: var(--background-color);
}

.single-post-layout {
    display: grid;
    grid-template-columns: 1fr 302px;
    gap: 46px;
}

.single-post-content {
    background-color: transparent;
    border-radius: 0;
    padding: 0;
}

.single-post-header {
    margin-bottom: 42px;
}

.single-post-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin-bottom: 20px;
}

.single-post-meta {
    display: flex;
    align-items: center;
    gap: 16px;
	padding-top: 40px;
}

.single-post-date {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 22px;
    color: var(--text-light);
}

.single-post-date svg {
    width: 28px;
    height: 28px;
}

.single-post-category {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: var(--secondary-color);
}

.single-post-date svg,
.single-post-category svg,
.single-event-meta-icon {
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
    object-fit: contain;
}

.single-post-image {
    margin-bottom: 42px;
    border-radius: 0;
    overflow: hidden;
}

.post-image {
    width: 100%;
    height: auto;
}

.single-post-body {
    max-width: 862px;
    font-size: 20px;
    line-height: 32px;
    letter-spacing: -0.02em;
    color: var(--text-color);
    margin-bottom: 42px;
}

body.single-news .single-post-body {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.single-post-body p {
    margin-bottom: 1em;
}

.single-post-body h2,
.single-post-body h3,
.single-post-body h4 {
    margin-top: 1.5em;
    margin-bottom: 0.5em;
}

.single-post-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 30px;
    border-top: 1px solid rgba(166, 178, 193, 0.3);
}

.single-post-tags {
    display: flex;
    align-items: center;
    gap: 10px;
}

.tags-label {
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: var(--text-color);
}

.tag-link {
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: var(--secondary-color);
    text-decoration: none;
}

.tag-link:hover {
    color: var(--primary-color);
}

.single-post-share {
    display: flex;
    align-items: center;
    gap: 10px;
}

.share-label {
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: var(--text-color);
}

.share-buttons {
    display: flex;
    align-items: center;
    gap: 8px;
}

.share-btn {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    text-decoration: none;
    transition: background-color 0.3s ease;
}

.share-vk {
    background-color: #4C75A3;
}

.share-telegram {
    background-color: #0088CC;
}

.share-btn svg {
    width: 16px;
    height: 16px;
    fill: var(--white);
}

.single-post-sidebar {
    position: sticky;
    top: 200px;
}

.sidebar-widget {
    background-color: var(--white);
    border-radius: var(--border-radius-sm);
    padding: 30px;
}

.widget-title {
    font-family: var(--font-primary);
    font-size: 22px;
    line-height: 28px;
    font-weight: 700;
    color: var(--text-color);
    text-transform: uppercase;
    letter-spacing: -0.02em;
    margin-bottom: 20px;
}

.other-news-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.other-news-item {
    padding-bottom: 20px;
    border-bottom: 1px solid rgba(166, 178, 193, 0.3);
}

.other-news-item:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.other-news-meta {
    margin-bottom: 10px;
}

.other-news-date {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 28px;
    color: var(--text-light);
}

.other-news-date svg {
    width: 24px;
    height: 24px;
}

.other-news-title {
    font-family: var(--font-secondary);
    font-size: 20px;
    line-height: 27px;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 10px;
}

.other-news-title a {
    color: inherit;
    text-decoration: none;
}

.other-news-title a:hover {
    color: var(--secondary-color);
}

.other-news-category {
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: var(--secondary-color);
}

/* ==========================================================================
   Страница
   ========================================================================== */

.page-content-section {
    padding: 80px 0;
    background-color: var(--background-color);
}

.page-layout {
    display: grid;
    grid-template-columns: 1fr 302px;
    gap: 34px;
}

.page-content {
    background-color: var(--white);
    border-radius: var(--border-radius-sm);
    padding: 40px;
}

.page-header {
    margin-bottom: 30px;
}

.page-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin: 0;
}

.page-image {
    margin-bottom: 30px;
    border-radius: var(--border-radius-sm);
    overflow: hidden;
}

.page-image img {
    width: 100%;
    height: auto;
}

.page-body {
    font-size: 16px;
    line-height: 24px;
    color: var(--text-color);
}

.page-body p {
    margin-bottom: 1em;
}

.page-body h2,
.page-body h3,
.page-body h4 {
    margin-top: 1.5em;
    margin-bottom: 0.5em;
}

.page-sidebar {
    position: sticky;
    top: 200px;
}

/* ==========================================================================
   404 страница
   ========================================================================== */

.error-404-section {
    padding: 140px 0;
    background-color: var(--background-color);
    text-align: center;
}

.error-404-title {
    font-size: 200px;
    line-height: 1;
    color: var(--primary-color);
    margin-bottom: 20px;
}

.error-404-subtitle {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin-bottom: 20px;
}

.error-404-description {
    font-size: 20px;
    line-height: 32px;
    color: var(--text-color);
    max-width: 500px;
    margin: 0 auto 30px;
}

.error-404-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
}

/* ==========================================================================
   Контент не найден
   ========================================================================== */

.content-none-section {
    padding: 140px 0;
    background-color: var(--background-color);
    text-align: center;
}

.content-none-title {
    font-size: 44px;
    line-height: 54px;
    color: var(--primary-color);
    margin-bottom: 20px;
}

.content-none-description {
    font-size: 20px;
    line-height: 32px;
    color: var(--text-color);
    max-width: 500px;
    margin: 0 auto 30px;
}

.content-none-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
}

/* ==========================================================================
   Пагинация
   ========================================================================== */

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

.pagination .nav-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.pagination .page-numbers {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 68px;
    height: 68px;
    border-radius: 50%;
    background-color: var(--white);
    font-family: var(--font-secondary);
    font-size: 18px;
    font-weight: 600;
    line-height: 25px;
    color: var(--text-color);
    text-decoration: none;
    transition: background-color 0.3s ease, color 0.3s ease;
}

.pagination .page-numbers:hover,
.pagination .page-numbers.current {
    background-color: var(--secondary-color);
    color: var(--white);
}

.pagination .prev,
.pagination .next {
    background-color: var(--white);
}

.pagination .prev:hover,
.pagination .next:hover {
    background-color: var(--secondary-color);
}

.pagination .prev svg,
.pagination .next svg {
    display: block;
    width: 10px;
    height: 15px;
}

.pagination .next:hover svg path {
    stroke: #2c3e50;
}

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ==========================================================================
   Адаптивность
   ========================================================================== */

@media (max-width: 1200px) {
    .hero-sidebar {
        display: none;
    }
    
    .quick-links-grid,
    .news-grid,
    .partners-grid,
    .blog-list-grid,
    .archive-list-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .directions-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 992px) {
    .header-contacts {
        display: none;
    }
    
    .mobile-menu-toggle {
        display: flex;
    }
    
    .main-navigation {
        display: none;
    }
    
    .hero-content {
        padding-left: 50px;
    }
    
    .hero-title {
        font-size: 36px;
        line-height: 44px;
    }
    
    .contact-form-wrapper,
    .newsletter-content,
    .gosuslugi-content {
        grid-template-columns: 1fr;
    }
    
    .single-post-layout,
    .page-layout {
        grid-template-columns: 1fr;
    }
    
    .single-post-sidebar,
    .page-sidebar {
        position: static;
    }
}

@media (max-width: 768px) {
    .header-search {
        display: none;
    }
    
    .quick-links-grid,
    .news-grid,
    .partners-grid,
    .blog-list-grid,
    .archive-list-grid,
    .directions-grid {
        grid-template-columns: 1fr;
    }
    
    .footer-grid {
        grid-template-columns: 1fr;
    }
    
    .hero-content {
        padding-left: 20px;
        padding-right: 20px;
    }
    
    .hero-title {
        font-size: 28px;
        line-height: 36px;
    }
    
    .section-title,
    .page-title,
    .blog-list-title,
    .archive-list-title,
    .single-post-title,
    .contact-form-title,
    .newsletter-title,
    .gosuslugi-title {
        font-size: 28px;
        line-height: 36px;
    }
    
    .form-row {
        grid-template-columns: 1fr;
    }
    
    .form-actions {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .blog-list-toolbar,
    .blog-list-filters {
        flex-direction: column;
        align-items: flex-start;
        width: 100%;
    }

    .filter-group {
        width: 100%;
    }

    .filter-group .form-control,
    .news-filter-trigger,
    .news-filter-period .news-filter-trigger,
    .news-filter-category .news-filter-trigger,
    .news-archive-trigger {
        width: 100%;
        min-width: 0;
    }

    .news-filter-dropdown,
    .news-filter-panel {
        width: 100%;
    }

    .news-filter-panel,
    .news-archive-panel {
        position: static;
        margin-top: 12px;
        width: 100%;
    }

    .news-filter-archive {
        width: 100%;
        margin-left: 0;
    }
    
    .single-post-footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }
    
    .error-404-title {
        font-size: 100px;
    }
}

@media (max-width: 576px) {
    .hero-slider-controls {
        left: 20px;
    }
    
    .hero-arrow {
        width: 48px;
        height: 48px;
    }
    
    .direction-card {
        width: 100%;
        height: auto;
        min-height: 400px;
    }
}

.contact-image-placeholder,
.app-screenshot-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 240px;
    padding: 24px;
    border: 2px dashed rgba(47, 180, 190, 0.4);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.65);
    color: var(--text-color);
    text-align: center;
}

.event-details-card {
    margin-bottom: 30px;
    padding: 24px 28px;
    border-radius: 24px;
    background-color: var(--white);
    box-shadow: 0 14px 54px -20px rgba(10, 61, 98, 0.2);
}

.event-details-card p:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   Макетные переопределения 2026
   ========================================================================== */

@media (min-width: 1201px) {
    :root {
        --container-width: 1310px;
        --container-padding: 0px;
    }

    .container,
    .container-fluid {
        width: 100%;
        max-width: 1310px;
        margin-right: auto;
        margin-left: auto;
        padding-right: 0;
        padding-left: 0;
    }
}

body {
    background: #edf3f8;
    color: #223850;
}

.site-header {
    position: relative;
    background: transparent;
}

.header-top {
    padding: 32px 0 40px;
    background: #f1f5f9;
}

.header-top-inner {
    display: grid;
    grid-template-columns: 254px minmax(0, 1fr);
    gap: 40px;
    align-items: start;
    justify-content: space-between;
    position: relative;
}

.header-logo {
    min-width: 254px;
    flex: 0 0 254px;
}

.site-logo {
    align-items: flex-start;
    gap: 12px;
}

.site-logo.site-logo-with-text {
    display: flex;
    align-items: center;
    gap: 18px;
    height: 92px;
}

.logo-full {
    width: 254px;
    height: 92px;
    flex: 0 0 254px;
}

.site-logo.site-logo-with-text .logo-full {
    width: 66px;
    height: 92px;
    flex: 0 0 66px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.site-logo.site-logo-with-text .logo-full img {
    width: 66px;
    height: 92px;
    object-fit: contain;
    object-position: center;
}

.logo-icon {
    width: 66px;
    height: 92px;
}

.logo-icon-fallback svg {
    width: 100%;
    height: 100%;
    display: block;
}

.logo-subtitle {
    font-size: 12px;
    line-height: 1.2;
    color: #2c3e50;
    display: block;
}

.logo-title {
    font-size: 14.37px;
    line-height: 18px;
    color: #0a3d62;
    display: block;
}

.site-logo.site-logo-with-text .logo-text {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 170px;
    padding-top: 0;
}

.header-main {
    width: 100%;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 26px;
    padding-top: 0;
}

.header-utility {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 30px;
    width: 100%;
}

.header-nav-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 42px;
    width: 100%;
}

.header-search {
    width: 312px;
    max-width: 312px;
    flex: 0 0 312px;
}

.search-form {
    min-height: 44px;
    padding: 8px 20px;
    background: #fff;
    box-shadow: none;
    border-radius: 999px;
}

.search-field {
    font-size: 16px;
    line-height: 20px;
    color: #2c3e50;
}

.search-submit svg {
    width: 28px;
    height: 28px;
}

.header-contacts {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 28px;
    flex-wrap: nowrap;
    width: auto;
    margin-left: auto;
}

.header-contact-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 28px;
}

.header-contact-item svg {
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
}

.header-contact-item .header-contact-icon {
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
}

.header-contact-item a,
.header-contact-item span {
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: #223850;
    white-space: nowrap;
}

.header-contact-item .upriu-accessibility-toggle {
    display: inline-flex;
    align-items: center;
    margin: 0;
    padding: 0;
    border: 0;
    background: transparent;
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    color: #223850;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
}

.header-contact-item .upriu-accessibility-toggle:hover {
    color: #2fb4be;
}

.main-navigation {
    flex: 1 1 auto;
    min-width: 0;
    background: transparent;
    border: 0;
}

.main-navigation ul {
    gap: 36px;
    justify-content: flex-start;
    flex-wrap: nowrap;
}

.main-navigation a {
    padding: 0;
    font-size: 16px;
    font-weight: 400;
    line-height: 22px;
    color: #223850;
    letter-spacing: -0.02em;
}

.main-navigation .sub-menu {
    top: calc(100% + 14px);
}

.header-drawer-meta {
    display: none;
}

.mobile-menu-toggle {
    margin-left: 0;
    display: flex;
    width: 24px;
    height: 20px;
    flex: 0 0 24px;
    justify-content: space-between;
    align-items: flex-end;
}

.mobile-menu-toggle span {
    width: 24px;
    height: 2.22px;
    background: #0a3d62;
    border-radius: 2px;
}

.mobile-menu-toggle span:nth-child(2) {
    width: 12px;
}

@media (min-width: 992px) {
    .mobile-menu-toggle {
        margin-right: 0;
    }
}

.breadcrumbs {
    padding: 16px 0 42px;
    font-size: 16px;
    line-height: 22px;
    letter-spacing: -0.02em;
    color: #a6b6c5;
}

.breadcrumbs a {
    color: #a6b6c5;
}

.page-title,
.archive-list-title,
.blog-list-title,
.single-post-title,
.contact-form-title,
.newsletter-title,
.gosuslugi-title,
.section-title {
    color: #0d4672;
    font-size: 44px;
    line-height: 54px;
    letter-spacing: -0.02em;
}

.btn {
    min-height: 68px;
    padding: 18px 40px;
    font-size: 18px;
    line-height: 32px;
    border-radius: 60px;
}

.btn-primary {
    background: #35c0cf;
    color: #fff;
}

.btn-primary:hover {
    background: #1596aa;
}

.hero-section {
    height: 788px;
    padding-bottom: 0;
}

.hero-slider {
    min-height: 788px;
    background: #0d4672;
    width: calc(100% - 755px);
}

.hero-slide,
.hero-slide.active {
    position: absolute;
    min-height: 788px;
    width: 100%;
}

.hero-slide-bg,
.hero-bg-placeholder,
.hero-overlay {
    width: 100%;
    height: 788px;
}

.hero-content {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: calc(100% - 755px);
    padding: 0;
    align-items: stretch;
    z-index: 12;
}

.hero-content > .container-fluid {
    position: relative;
    width: 100%;
    height: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
}

.hero-title {
    position: absolute;
    left: 120px;
    bottom: 228px;
    width: min(1040px, calc(100% - 160px));
    font-size: 52px;
    line-height: 63px;
    text-transform: uppercase;
    margin: 0;
    max-width: none;
    text-wrap: normal;
    word-break: normal;
}

.hero-content .btn {
    position: absolute;
    left: 120px;
    bottom: 92px;
    min-width: 247px;
    min-height: 68px;
    padding: 18px 40px;
    font-size: 18px;
    line-height: 32px;
    background: #ffffff;
    color: #2c3e50;
    box-shadow: none;
    z-index: 14;
    pointer-events: auto;
}

.hero-content .btn:hover {
    background: #ffffff;
    color: #0a3d62;
}

.hero-meta {
    display: none;
}

.hero-slider-controls {
    left: auto;
    right: calc(755px + 120px);
    bottom: 92px;
    gap: 20px;
    align-items: center;
}

.hero-slider-dots {
    display: none;
}

.hero-slider-counter {
    font-family: var(--font-secondary);
    font-size: 18px;
    line-height: 32px;
    color: #ffffff;
}

.hero-arrow {
    width: 68px;
    height: 68px;
    box-shadow: none;
}

.hero-sidebar {
    top: 0;
    width: 755px;
    height: 788px;
    gap: 12px;
    background: #f1f5f9;
    padding-left: 12px;
}

.hero-sidebar-card {
    width: 743px;
    height: 188px;
    padding: 0 80px;
    gap: 40px;
    border-bottom: 0;
    background: #ffffff;
    text-decoration: none;
    color: inherit;
}

.hero-sidebar-card:hover {
    background: #ffffff;
    color: inherit;
}

.hero-sidebar-icon {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-sidebar-icon img,
.hero-sidebar-icon svg {
    display: block;
    width: 80px;
    height: 80px;
    object-fit: contain;
}

.hero-sidebar-title {
    font-size: 22px;
    line-height: 28px;
    max-width: 380px;
    letter-spacing: -0.02em;
}

.hero-sidebar-link {
    display: none;
}

.quick-links-section {
    display: none;
}

body.home .news-section > .container-fluid,
body.home .directions-section > .container-fluid,
body.home .partners-section > .container-fluid,
body.home .contact-form-section > .container-fluid,
body.home .home-contacts-map > .container-fluid {
    max-width: 1310px;
}

body.home .partner-strip-section > .container-fluid {
    max-width: 1310px;
}

body.home .newsletter-section > .container-fluid,
body.home .gosuslugi-section > .container-fluid {
    max-width: 1310px;
    padding: 0;
}

.news-section,
.directions-section,
.partners-section,
.contact-form-section {
    padding: 120px 0 120px;
    background: #f1f5f9;
}

.newsletter-section,
.gosuslugi-section,
.partner-strip-section,
.home-contacts-section {
    background: #f1f5f9;
}

.section-header {
    margin-bottom: 64px;
    align-items: center;
}

.section-link {
    font-weight: 700;
    font-size: 20px;
    gap: 12px;
}

.section-link svg {
    width: 8px;
    height: 16px;
}

.section-title {
    font-size: 44px;
    line-height: 54px;
}

.news-section .news-grid {
    grid-template-columns: repeat(4, 302px);
    gap: 34px;
}

.news-section .news-card {
    width: 302px;
    height: 464px;
    min-height: 464px;
    max-height: 464px;
    border-radius: 0;
    box-shadow: none;
    background: #ffffff;
    overflow: hidden;
}

body.home .news-section .news-card {
    height: 464px;
    min-height: 464px;
    max-height: 464px;
}

body.home .news-section .news-card-image,
body.home .news-section .news-card-image a,
body.home .news-section .news-image,
body.home .news-section .news-image-placeholder {
    height: 224px;
}

body.home .news-section .news-card-body {
    height: 240px;
}

.news-card-image {
    width: 302px;
    height: 224px;
}

.news-card-image a,
.news-image,
.news-image-placeholder {
    display: block;
    width: 302px;
    height: 224px;
}

.news-image {
    object-fit: cover;
}

.news-card-body {
    display: flex;
    flex-direction: column;
    height: 240px;
    padding: 30px;
}

.news-card-date,
.news-card-category,
.single-post-date,
.other-news-date {
    font-size: 16px;
    line-height: 22px;
}

.news-card-date svg {
    width: 21px;
    height: 25px;
    flex: 0 0 21px;
}

.news-card-date {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    color: #a6b2c1;
    margin-bottom: 24px;
}

.news-card-title {
    font-size: 20px;
    line-height: 28px;
    min-height: 84px;
    margin-bottom: 0;
    letter-spacing: -0.02em;
    text-transform: none;
}

.news-card-title a {
    color: #2c3e50;
    text-transform: none;
}

.news-card-category {
    font-weight: 700;
    margin-top: auto;
    padding-top: 0;
    color: #2fb4be;
    letter-spacing: -0.02em;
}

.directions-grid {
    grid-template-columns: repeat(3, 414px);
    gap: 34px;
}

.direction-card {
    width: 414px;
    height: 540px;
    padding: 50px;
    border-radius: 0;
}

.direction-icon {
    position: absolute;
    right: -60px;
    bottom: auto;
    top: 110px;
    width: 240px;
    height: 240px;
    opacity: 0.2;
}

.direction-icon svg {
    width: 100%;
    height: 100%;
}

.direction-title {
    max-width: 328px;
    font-size: 22px;
    line-height: 28px;
    position: relative;
    z-index: 2;
    margin-bottom: 30px;
}

.direction-number {
    width: 68px;
    height: 68px;
    font-size: 22px;
    margin-bottom: 284px;
}

.direction-link {
    position: relative;
    z-index: 2;
    font-size: 20px;
    gap: 12px;
}

.partners-tabs {
    display: flex;
    gap: 32px;
    align-items: center;
}

.partner-tab {
    border: 0;
    background: transparent;
    padding: 0;
    border-radius: 0;
    color: #6d8091;
    font-size: 20px;
    line-height: 20px;
}

.partner-tab.active,
.partner-tab:hover {
    background: transparent;
    color: #0d4672;
}

.partners-section .partners-grid {
    grid-template-columns: repeat(3, 414px);
    gap: 34px;
}

.partner-card {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 414px;
    height: 190px;
    border-radius: 0;
    box-shadow: none;
    padding: 49px 20px 49px 138px;
}

.partner-logo,
.partner-logo-placeholder {
    position: absolute;
    left: 50px;
    top: 50%;
    width: 60px;
    height: 60px;
    margin-bottom: 0;
    transform: translateY(-50%);
}

.partner-logo {
    object-fit: contain;
}

.partner-name {
    max-width: 260px;
    font-size: 18px;
    line-height: 24px;
    color: #223850;
    text-align: left;
}

.partners-section .partner-card {
    display: grid;
    grid-template-columns: 60px minmax(0, 1fr);
    align-content: center;
    column-gap: 28px;
    padding: 0 42px 0 50px;
}

.partners-section .partner-card.is-hidden {
    display: none;
}

.partners-section .partner-logo,
.partners-section .partner-logo-placeholder {
    position: static;
    left: auto;
    top: auto;
    transform: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

.partners-section .partner-name {
    align-self: center;
    margin: 0;
}

.contact-form-section {
    padding: 140px 0 40px;
    min-height: 858px;
    background: rgba(13, 70, 114, 0.04);
}

.contact-form-wrapper {
    grid-template-columns: minmax(0, 1fr) 638px;
    gap: 174px;
    align-items: start;
}

.contact-form-container {
    background: transparent;
    padding: 0;
    border-radius: 0;
    width: 638px;
}

.contact-form-title {
    font-size: 44px;
    line-height: 54px;
    max-width: 386px;
    margin-bottom: 40px;
}

.contact-form-description {
    font-size: 20px;
    line-height: 32px;
    max-width: 498px;
    margin-bottom: 56px;
}

.contact-form-image img {
    width: 476px;
}

.contact-form .form-row {
    grid-template-columns: repeat(2, 313px);
    gap: 12px;
}

.form-control {
    min-height: 68px;
    padding: 18px 32px;
    font-size: 16px;
    line-height: 32px;
    border-radius: 60px;
    box-shadow: inset 0 0 0 1px rgba(13, 70, 114, 0.06);
}

textarea.form-control {
    min-height: 298px;
    border-radius: 34px;
}

.form-actions {
    justify-content: flex-start;
    align-items: flex-start;
    gap: 44px;
    margin-top: 12px;
}

.form-disclaimer,
.newsletter-disclaimer {
    max-width: 281px;
    font-size: 16px;
    line-height: 22px;
}

.form-actions .btn {
    min-width: 313px;
    min-height: 68px;
    padding: 18px 40px;
}

.newsletter-section {
    padding: 140px 0 128px;
    height: 522px;
    min-height: 522px;
    background: #0a3d62;
}

.newsletter-section::before {
    content: "";
    position: absolute;
    left: -256px;
    bottom: -252px;
    width: 513px;
    height: 513px;
    border-radius: 50%;
    background: #2fb4be;
    filter: blur(200px);
    opacity: 0.9;
}

.newsletter-section .newsletter-overlay {
    background: transparent;
}

.newsletter-content {
    grid-template-columns: minmax(0, 1fr) 361px;
    gap: 84px;
    align-items: start;
}

.newsletter-title {
    max-width: 865px;
    font-size: 44px;
    line-height: 54px;
    color: #fff;
    margin-bottom: 44px;
}

.newsletter-description {
    font-size: 20px;
    line-height: 28px;
    color: rgba(255, 255, 255, 0.92);
    margin-bottom: 0;
}

.newsletter-form-container {
    background: transparent;
    padding: 0;
    width: 361px;
}

.newsletter-form .form-control {
    background: #f1f5f9;
    min-height: 68px;
}

.newsletter-form .btn {
    width: 100%;
    min-height: 68px;
    padding: 18px 40px;
    margin-top: 12px;
}

.newsletter-form .newsletter-disclaimer {
    width: 361px;
    max-width: 361px;
    margin: 8px auto 0;
    text-align: center;
}

.gosuslugi-section {
    position: relative;
    box-sizing: border-box;
    height: 642px;
    min-height: 642px;
    padding: 140px 0;
    overflow: hidden;
    background: #0a3d62;
}

.gosuslugi-section::before {
    content: "";
    position: absolute;
    left: -210px;
    bottom: -230px;
    z-index: 2;
    width: 620px;
    height: 620px;
    border-radius: 50%;
    background: #2FB4BE;
    filter: blur(180px);
    opacity: 0.82;
    pointer-events: none;
}

.gosuslugi-content {
    position: relative;
    display: block;
    min-height: 362px;
}

.gosuslugi-title {
    max-width: 760px;
    font-size: 34px;
    line-height: 44px;
    color: #ffffff;
    margin-bottom: 30px;
}

.gosuslugi-description {
    font-size: 16px;
    line-height: 24px;
    color: rgba(255, 255, 255, 0.96);
    margin-bottom: 34px;
}

.gosuslugi-section .btn {
    min-width: 285px;
    min-height: 68px;
    padding: 18px 40px;
}

.gosuslugi-info {
    position: relative;
    z-index: 3;
    max-width: 760px;
    padding-top: 0;
}

.gosuslugi-image {
    position: absolute;
    top: 45%;
    right: -96px;
    z-index: 1;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    width: 980px;
    height: 642px;
    min-height: 0;
    transform: translateY(-50%);
    margin-right: 0;
    pointer-events: none;
}

.gosuslugi-image img {
    display: block;
    width: 980px;
    max-width: none;
    height: 642px;
    object-fit: cover;
    object-position: center center;
    filter: saturate(1.02);
}

.partner-strip-section {
    padding: 152px 0 116px;
    background: #fff;
}

.section-header-centered {
    justify-content: center;
}

.partner-strip-list {
    display: flex;
    gap: 34px;
    align-items: center;
    transition: transform 0.35s ease;
    will-change: transform;
}

.partner-strip-viewport {
    overflow: hidden;
}

.partner-strip-item {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 119px;
    color: #223850;
    flex: 0 0 calc((100% - 136px) / 5);
}

.partner-strip-logo {
    max-width: 100%;
    max-height: 88px;
    object-fit: contain;
}

.partner-strip-placeholder {
    font-size: 24px;
    font-weight: 700;
    color: #7891a7;
}

.partner-strip-controls {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 64px;
}

.partner-strip-controls .hero-arrow {
    width: 68px;
    height: 68px;
    background: #2fb4be;
    color: #fff;
}

.partner-strip-controls .hero-arrow:hover {
    background: #0d4672;
    color: #fff;
}

.partner-strip-controls .hero-arrow:disabled {
    opacity: 0.45;
    cursor: default;
}

.home-contacts-section {
    background: #fff;
}

.home-contacts-map {
    position: relative;
    padding: 152px 0 140px;
    min-height: 797px;
    overflow: hidden;
    background: #ffffff;
}

.home-contacts-map-embed {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}

.home-contacts-map-embed a {
    color: #eee;
    font-size: 12px;
    position: absolute;
    left: 0;
    z-index: 1;
}

.home-contacts-map-embed a:first-child {
    top: 0;
}

.home-contacts-map-embed a:nth-child(2) {
    top: 14px;
}

.home-contacts-map-embed iframe {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 797px;
    border: 0;
}

.home-contacts-map > .container-fluid {
    position: relative;
    z-index: 2;
    pointer-events: none;
}

.home-contacts-card {
    width: 526px;
    height: 517px;
    padding: 60px;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 18px 40px -28px rgba(13, 70, 114, 0.35);
    pointer-events: auto;
    transform: translateX(-300px);
}

.home-contacts-card .content-section-title {
    margin-bottom: 56px;
    font-size: 44px;
    line-height: 54px;
}

.home-contacts-list {
    display: flex;
    flex-direction: column;
    gap: 22px;
    margin-bottom: 84px;
    font-size: 20px;
    line-height: 27px;
}

.home-contacts-item {
    display: flex;
    align-items: center;
    gap: 17px;
    font-size: 20px;
    line-height: 27px;
    color: #2c3e50;
}

.home-contacts-item a,
.contact-simple-item a {
    font-size: inherit;
    line-height: inherit;
    color: inherit;
    text-decoration: none;
}

.home-contacts-item a:hover,
.contact-simple-item a:hover {
    color: #2fb4be;
}

.home-contacts-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    color: #2fb4be;
    flex: 0 0 28px;
}

.home-contacts-icon svg {
    width: 28px;
    height: 28px;
}

.home-contacts-icon img,
.contact-ui-icon {
    display: block;
    width: 28px;
    height: 28px;
    object-fit: contain;
    flex: 0 0 28px;
}

.home-contacts-card .btn {
    min-width: 406px;
    min-height: 68px;
    padding: 18px 40px;
}

.contact-modal-open {
    overflow: hidden;
}

.contact-modal {
    position: fixed;
    inset: 0;
    z-index: 3000;
    display: none;
    align-items: flex-start;
    justify-content: center;
    padding: 60px 24px;
    overflow-y: auto;
}

.contact-modal.is-open {
    display: flex;
}

.contact-modal__backdrop {
    position: fixed;
    inset: 0;
    background: rgba(4, 31, 51, 0.72);
}

.contact-modal__dialog {
    position: relative;
    z-index: 1;
    width: 862px;
    min-height: 936px;
    padding: 60px 112px;
    background: #0a3d62;
    color: #ffffff;
}

.contact-modal__close {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 24px;
    height: 24px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.contact-modal__close span {
    position: absolute;
    left: 3px;
    top: 11px;
    width: 24px;
    height: 2px;
    background: #ffffff;
    transform-origin: center;
}

.contact-modal__close span:first-child {
    transform: rotate(-45deg);
}

.contact-modal__close span:last-child {
    transform: rotate(45deg);
}

.contact-modal__title {
    width: 494px;
    max-width: 100%;
    margin: 0 auto 34px;
    color: #ffffff;
    font-size: 44px;
    line-height: 54px;
    font-weight: 700;
    text-align: center;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.contact-modal__description {
    width: 498px;
    max-width: 100%;
    margin: 0 auto 66px;
    color: #ffffff;
    font-size: 20px;
    line-height: 32px;
    font-weight: 400;
    text-align: center;
    letter-spacing: -0.02em;
}

.contact-modal__form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.contact-modal__row {
    display: grid;
    grid-template-columns: repeat(2, 313px);
    gap: 12px;
}

.contact-modal__form .form-control {
    width: 100%;
    min-height: 68px;
    padding: 18px 32px;
    border: 0;
    border-radius: 60px;
    background: rgba(255, 255, 255, 0.1);
    color: #ffffff;
    font-size: 18px;
    line-height: 32px;
    letter-spacing: -0.02em;
    box-shadow: none;
}

.contact-modal__form .form-control::placeholder {
    color: rgba(255, 255, 255, 0.92);
}

.contact-modal__form .form-control:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(47, 180, 190, 0.72);
}

.contact-modal__message {
    width: 638px;
    min-height: 298px;
    resize: vertical;
    border-radius: 34px !important;
}

.contact-modal__actions {
    display: grid;
    grid-template-columns: 313px 281px;
    gap: 44px;
    align-items: start;
    margin-top: 40px;
}

.contact-modal__actions .btn {
    width: 313px;
    min-height: 68px;
    padding: 18px 40px;
    border-radius: 60px;
    font-size: 18px;
    line-height: 32px;
    font-weight: 700;
}

.contact-modal__actions .form-disclaimer {
    margin: 1px 0 0;
    color: #a6b2c1;
    font-size: 16px;
    line-height: 22px;
    letter-spacing: -0.02em;
}

.contact-modal__form .form-message {
    margin-top: 18px;
    color: #ffffff;
}

.footer-about .site-logo {
    align-items: flex-start;
}

.footer-about .logo-full {
    width: 271px;
    height: auto;
    flex: 0 0 271px;
}

.footer-app .app-screenshot {
    width: 229px;
    height: 450px;
    border-radius: 4px;
    overflow: hidden;
}

.footer-app .app-screenshot img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.footer-gosuslugi-widget iframe {
    display: block;
    width: 229px;
    max-width: 100%;
    height: 450px;
    border: 0;
}

.footer-home-style {
    background: #f1f5f9;
}

.footer-home-style .footer-main {
    padding: 148px 0 132px;
}

.footer-home-style .footer-grid {
    display: grid;
    grid-template-columns: 271px 124px 286px 229px;
    justify-content: space-between;
    column-gap: 72px;
    align-items: stretch;
    min-height: 450px;
}

.footer-home-style .footer-about {
    max-width: none;
    min-height: 450px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.footer-home-style .footer-logo {
    margin-bottom: 0;
}

.footer-home-style .footer-nav h4,
.footer-home-style .footer-contacts h4,
.footer-home-style .footer-app h4 {
    display: none;
}

.footer-home-style .footer-home-logo {
    display: flex;
    align-items: flex-start;
    gap: 11px;
    width: 271px;
    text-decoration: none;
}

.footer-home-style .footer-home-logo .logo-icon {
    width: 86px;
    height: 107px;
    flex: 0 0 86px;
}

.footer-home-style .footer-home-logo .logo-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.footer-home-style .footer-home-logo .logo-text {
    display: flex;
    flex-direction: column;
    padding-top: 0;
}

.footer-home-style .footer-home-logo .logo-subtitle {
    width: 148px;
    margin-bottom: 8px;
    font-size: 12.2645px;
    line-height: 120%;
    letter-spacing: -0.02em;
    color: #a8b9cb;
}

.footer-home-style .footer-home-logo .logo-title {
    width: 174px;
    font-size: 14.6829px;
    line-height: 18px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #2c3e50;
}

.footer-home-style .footer-nav,
.footer-home-style .footer-contacts,
.footer-home-style .footer-app {
    min-height: auto;
}

.footer-home-style .footer-nav,
.footer-home-style .footer-contacts {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.footer-home-style .footer-nav ul {
    display: flex;
    flex-direction: column;
    gap: 0;
    height: 100%;
    min-height: 450px;
    justify-content: space-between;
    list-style: none;
}

.footer-home-style .footer-nav li {
    margin-bottom: 0;
}

.footer-home-style .footer-nav a {
    font-size: 16px;
    line-height: 22px;
    color: #31465c;
}

.footer-home-style .footer-contact-item {
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    column-gap: 12px;
    row-gap: 8px;
    align-items: center;
    margin-bottom: 0;
}

.footer-home-style .footer-contact-item:last-child {
    margin-bottom: 0;
}

.footer-home-style .footer-contact-item svg,
.footer-home-style .footer-contact-item .contact-ui-icon {
    flex: 0 0 28px;
    margin-top: 0;
}

.footer-home-style .footer-contact-text {
    display: contents;
}

.footer-home-style .footer-contact-label {
    font-size: 16px;
    line-height: 22px;
    font-weight: 400;
    color: #a6b2c1;
}

.footer-home-style .footer-contact-value,
.footer-home-style .footer-contact-value:hover {
    grid-column: 1 / -1;
    font-size: 20px;
    line-height: 27px;
    color: #31465c;
    text-decoration: none;
}

.footer-home-style .footer-home-legal {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}

.footer-home-style .copyright-home {
    margin: 0 0 6px;
    max-width: 243px;
    font-size: 16px;
    line-height: 22px;
    color: #31465c;
}

.footer-home-style .footer-home-legal a {
    font-size: 16px;
    line-height: 22px;
    color: #2fb4be;
    text-decoration: none;
}

.footer-home-style .footer-home-legal a:hover {
    color: #0d4672;
}

.footer-home-style .footer-app {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
}

.footer-home-style .footer-bottom {
    display: none;
}

.footer-home-style .footer-bottom-inner {
    justify-content: flex-start;
}

.footer-home-style .copyright {
    max-width: 243px;
    font-size: 16px;
    line-height: 22px;
}

.cooperation-page-section {
    min-height: 610px;
    padding-bottom: 120px;
}

.cooperation-page-content {
    padding-top: 0;
}

.cooperation-page-content .page-title {
    margin-bottom: 56px;
}

.cooperation-grid {
    display: grid;
    grid-template-columns: repeat(4, 302px);
    gap: 34px;
    justify-content: space-between;
}

.cooperation-card {
    width: 302px;
    min-height: 420px;
    padding: 30px;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.cooperation-card-icon {
    width: 80px;
    height: 80px;
    margin-bottom: 152px;
    color: #2fb4be;
}

.cooperation-card-icon img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.cooperation-card-title {
    max-width: 263px;
    margin: 0 0 auto;
    font-size: 22px;
    font-weight: 600;
    line-height: 28px;
    letter-spacing: -0.02em;
    color: #2c3e50;
    text-transform: uppercase;
}

.cooperation-card-link {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-top: 30px;
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    color: #2fb4be;
}

.cooperation-card-link svg {
    width: 8px;
    height: 16px;
}

.cooperation-card-link:hover {
    color: #0d4672;
}

.consumer-page-section {
    padding-bottom: 96px;
}

.consumer-page-content {
    max-width: 1310px;
}

.consumer-page-content .page-title {
    margin-bottom: 46px;
}

.consumer-page-content .pill-tabs {
    display: grid;
    grid-template-columns: repeat(3, max-content);
    gap: 12px;
    max-width: 1310px;
    margin: 0 0 56px;
    justify-content: start;
    align-items: start;
}

.consumer-page-content .pill-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 68px;
    padding: 18px 28px;
    max-width: 100%;
    border: 0;
    border-radius: 34px;
    background: #ffffff;
    color: #2c3e50;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    font-weight: 400;
    font-style: normal;
    line-height: 32px;
    letter-spacing: -0.02em;
    box-shadow: none;
    cursor: pointer;
    text-align: center;
    white-space: nowrap;
    width: auto;
}

.consumer-page-content .pill-tab.is-active {
    background: #35c0cf;
    color: #ffffff;
}

.consumer-doc-panel {
    display: none;
}

.consumer-doc-panel.is-active {
    display: block;
}

.consumer-page-content .content-section-block {
    margin-top: 0;
}

.consumer-page-content .content-section-title {
    margin-bottom: 36px;
}

.consumer-page-content .doc-card-grid-3 {
    grid-template-columns: repeat(3, 414px);
    gap: 34px;
    justify-content: space-between;
}

.consumer-page-content .doc-link-card {
    width: 414px;
    min-height: 128px;
    height: 128px;
    padding: 32px 46px;
    gap: 24px;
    background: #ffffff;
    box-shadow: none;
}

.consumer-page-content .doc-link-card span:last-child {
    display: -webkit-box;
    max-width: 224px;
    min-width: 0;
    overflow: hidden;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 24px;
    font-weight: 600;
    letter-spacing: -0.02em;
    vertical-align: middle;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
}

.consumer-page-content .doc-icon {
    width: 60px;
    height: 60px;
    border-radius: 0;
    background: transparent;
    font-size: 16px;
    line-height: 1;
    clip-path: none;
}

.support-navigator-page-section {
    padding-bottom: 0;
}

.support-navigator-page-content {
    max-width: 1310px;
}

.support-navigator-page-content .page-title {
    margin-bottom: 54px;
}

.support-navigator-category {
    margin: 0 0 78px;
}

.support-navigator-category:last-child {
    margin-bottom: 120px;
}

.support-navigator-category .content-section-title {
    margin-bottom: 32px;
    text-align: center;
}

.support-navigator-grid.doc-card-grid-3 {
    grid-template-columns: repeat(3, 414px);
    gap: 34px;
    justify-content: space-between;
}

.support-navigator-grid .doc-link-card {
    width: 414px;
    min-height: 128px;
    height: 128px;
    padding: 32px 46px;
    gap: 24px;
    background: #ffffff;
    box-shadow: none;
}

.support-navigator-grid .doc-link-card span:last-child {
    display: -webkit-box;
    max-width: 224px;
    min-width: 0;
    overflow: hidden;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 24px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: #2c3e50;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
}

.support-navigator-grid .doc-icon {
    width: 60px;
    height: 60px;
    flex: 0 0 60px;
    border-radius: 0;
    background: transparent;
    clip-path: none;
}

.financial-results-page-section {
    padding-bottom: 120px;
}

.financial-results-page-content {
    max-width: 1310px;
}

.financial-results-page-content .page-title {
    max-width: 1180px;
    margin-bottom: 64px;
}

.financial-results-grid.doc-card-grid-3 {
    grid-template-columns: repeat(3, 414px);
    gap: 34px;
    justify-content: space-between;
}

.financial-results-grid .doc-link-card {
    width: 414px;
    height: 128px;
    min-height: 128px;
    padding: 32px 46px;
    gap: 24px;
    background: #ffffff;
    box-shadow: none;
}

.financial-results-grid .doc-link-card span:last-child {
    display: -webkit-box;
    max-width: 224px;
    min-width: 0;
    overflow: hidden;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 24px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: #2c3e50;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
}

.financial-results-grid .doc-icon {
    width: 60px;
    height: 60px;
    flex: 0 0 60px;
    border-radius: 0;
    background: transparent;
    clip-path: none;
}

.reporting-page-section {
    min-height: 980px;
    padding-bottom: 120px;
}

.reporting-page-content {
    padding-top: 0;
    max-width: 1310px;
}

.reporting-page-content .page-title {
    margin-bottom: 56px;
}

.reporting-grid {
    display: grid;
    grid-template-columns: repeat(3, 412px);
    gap: 34px;
    justify-content: space-between;
}

.reporting-card {
    width: 412px;
    min-height: 420px;
    padding: 30px;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.reporting-card-icon {
    width: 80px;
    height: 80px;
    margin-bottom: 100px;
    color: #2fb4be;
}

.reporting-card-icon svg,
.reporting-card-icon img {
    display: block;
    width: 100%;
    height: 100%;
}

.reporting-card-title {
    max-width: 331px;
    margin: 0 0 auto;
    font-size: 22px;
    font-weight: 600;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #31465c;
}

.reporting-card-link {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-top: 34px;
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    color: #2fb4be;
}

.reporting-card-link svg {
    width: 8px;
    height: 16px;
}

.reporting-card-link:hover {
    color: #0d4672;
}

.reporting-card--years.is-open {
    padding-bottom: 20px;
}

.reporting-card-years-toggle {
    border: 0;
    background: transparent;
    padding: 0;
    cursor: pointer;
}

.reporting-card-years-toggle-label {
    display: inline-block;
}

.reporting-card--years.is-open .reporting-card-years-toggle {
    display: none;
}

.reporting-card-years-menu {
    width: 100%;
    margin-top: 16px;
}

.reporting-card-year-link,
.reporting-card-years-collapse {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 36px;
    padding: 0;
    border: 0;
    border-top: 1px solid #e8eef3;
    background: transparent;
    color: #0d4672;
    font-family: 'Open Sans', sans-serif;
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    letter-spacing: -0.02em;
    text-decoration: none;
}

.reporting-card-year-link {
    padding-top: 12px;
}

.reporting-card-years-collapse {
    margin-top: 4px;
    padding-top: 12px;
    color: #2fb4be;
    cursor: pointer;
}

.reporting-card-years-collapse svg {
    width: 8px;
    height: 16px;
    transform: rotate(-90deg);
}

.consumer-market-page-section {
    padding-bottom: 120px;
}

.consumer-market-page-content {
    max-width: 1310px;
    padding-top: 0;
}

.consumer-market-page-content .page-title {
    margin-bottom: 56px;
}

.consumer-market-grid {
    display: grid;
    grid-template-columns: repeat(3, 414px);
    gap: 34px;
    justify-content: space-between;
}

.consumer-market-card {
    position: relative;
    width: 414px;
    height: 420px;
    padding: 50px 30px 30px;
    background: #ffffff;
}

.consumer-market-card-icon {
    display: block;
    width: 80px;
    height: 80px;
    object-fit: contain;
}

.consumer-market-card-title {
    position: absolute;
    left: 30px;
    right: 30px;
    top: 190px;
    max-width: 300px;
    margin: 0;
    color: #2c3e50;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 600;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.consumer-market-card-link {
    position: absolute;
    left: 30px;
    bottom: 30px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 0;
    border: 0;
    background: transparent;
    color: #2fb4be;
    cursor: pointer;
    font-family: var(--font-secondary);
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
    letter-spacing: -0.02em;
}

.consumer-market-card-link svg {
    display: block;
    width: 8px;
    height: 16px;
}

.consumer-market-card-link:hover {
    color: #0a3d62;
}

.consumer-market-modal-open {
    overflow: hidden;
}

.consumer-market-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 32px;
}

.consumer-market-modal.is-open {
    display: flex;
}

.consumer-market-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 61, 98, 0.18);
}

.consumer-market-modal__dialog {
    position: relative;
    width: 638px;
    min-height: 512px;
    padding: 48px 50px 42px;
    background: #0a3d62;
    color: #ffffff;
    box-shadow: 0 24px 80px rgba(10, 61, 98, 0.22);
}

.consumer-market-modal__close {
    position: absolute;
    top: 24px;
    right: 24px;
    width: 28px;
    height: 28px;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.consumer-market-modal__close span {
    position: absolute;
    top: 13px;
    left: 2px;
    width: 24px;
    height: 2px;
    background: #ffffff;
}

.consumer-market-modal__close span:first-child {
    transform: rotate(45deg);
}

.consumer-market-modal__close span:last-child {
    transform: rotate(-45deg);
}

.consumer-market-modal__title {
    max-width: 430px;
    margin: 0 0 28px;
    color: #ffffff;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.consumer-market-modal__title span {
    display: block;
    color: #2fb4be;
}

.consumer-market-modal__list {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin: 0 0 42px;
    padding: 0 0 0 18px;
    color: #ffffff;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
    letter-spacing: -0.02em;
}

.consumer-market-modal__list a {
    color: #ffffff;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.consumer-market-modal__list a:hover {
    color: #2fb4be;
}

.consumer-market-modal__text {
    margin: 0 0 42px;
    color: #ffffff;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.consumer-market-modal__text p,
.consumer-market-modal__text ul,
.consumer-market-modal__text ol {
    margin: 0 0 18px;
}

.consumer-market-modal__text p:last-child,
.consumer-market-modal__text ul:last-child,
.consumer-market-modal__text ol:last-child {
    margin-bottom: 0;
}

.consumer-market-modal__text ul,
.consumer-market-modal__text ol {
    padding-left: 22px;
}

.consumer-market-modal__text a {
    color: #ffffff;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.consumer-market-modal__text a:hover {
    color: #2fb4be;
}

.consumer-market-modal__download {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 150px;
    height: 68px;
    border: 0;
    border-radius: 60px;
    background: #2fb4be;
    color: #ffffff;
    cursor: pointer;
    font-family: var(--font-secondary);
    font-size: 18px;
    font-weight: 700;
    line-height: 32px;
    letter-spacing: -0.02em;
    text-decoration: none;
}

.consumer-market-modal__download[disabled] {
    opacity: 0.45;
    cursor: default;
}

@media (max-width: 1400px) {
    .consumer-market-grid {
        grid-template-columns: repeat(2, minmax(0, 414px));
    }
}

@media (max-width: 900px) {
    .consumer-market-grid {
        grid-template-columns: 1fr;
    }

    .consumer-market-card {
        width: 100%;
        max-width: 414px;
    }

    .consumer-market-modal {
        padding: 18px;
    }

    .consumer-market-modal__dialog {
        width: 100%;
        min-height: auto;
        padding: 42px 28px 32px;
    }
}

.msp-page-section {
    min-height: 1280px;
}

.msp-page-content {
    max-width: 1310px;
    padding-top: 0;
}

.msp-hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 638px;
    gap: 75px;
    align-items: start;
}

.msp-copy .page-title,
.msp-support-title {
    margin-bottom: 56px;
    font-weight: 600;
    text-transform: uppercase;
}

.msp-copy .section-copy {
    max-width: 598px;
    color: #2c3e50;
    font-size: 20px;
    line-height: 32px;
    letter-spacing: -0.02em;
}

.msp-copy .section-copy p {
    margin: 0 0 32px;
}

.msp-registry-card {
    min-height: 420px;
    padding: 40px;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.msp-registry-icon {
    width: 80px;
    height: 80px;
    margin-bottom: 44px;
    color: #2fb4be;
}

.msp-registry-icon svg {
    display: block;
    width: 100%;
    height: 100%;
}

.msp-registry-icon img,
.msp-support-icon img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.msp-registry-title {
    max-width: 263px;
    margin: 0 0 auto;
    color: #2c3e50;
    font-size: 22px;
    font-weight: 600;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.msp-registry-links {
    display: flex;
    flex-wrap: wrap;
    gap: 18px 30px;
    margin-top: 34px;
}

.msp-registry-link,
.msp-support-card-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #2fb4be;
    font-family: var(--font-secondary);
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
}

.msp-registry-link svg,
.msp-support-card-link svg {
    width: 8px;
    height: 16px;
}

.msp-registry-link:hover,
.msp-support-card-link:hover {
    color: #0d4672;
}

.msp-support-block {
    margin-top: 76px;
}

.msp-support-grid {
    display: grid;
    grid-template-columns: repeat(3, 412px);
    gap: 34px;
    justify-content: space-between;
}

.msp-support-card {
    width: 412px;
    min-height: 420px;
    padding: 30px;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.msp-support-icon {
    width: 80px;
    height: 80px;
    margin-bottom: 154px;
    color: #2fb4be;
}

.msp-support-icon svg {
    display: block;
    width: 100%;
    height: 100%;
}

.msp-support-card-title {
    max-width: 300px;
    margin: 0 0 auto;
    color: #2c3e50;
    font-size: 22px;
    font-weight: 600;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.msp-support-card-link {
    appearance: none;
    border: 0;
    background: transparent;
    padding: 0;
    margin-top: 34px;
    font-size: 20px;
    line-height: 20px;
    cursor: pointer;
}

.msp-support-block {
    padding-bottom: 120px;
}

.msp-support-modal-open {
    overflow: hidden;
}

.msp-support-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
}

.msp-support-modal.is-open {
    display: flex;
}

.msp-support-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.62);
}

.msp-support-modal__dialog {
    position: relative;
    width: min(862px, 100%);
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    padding: 60px 70px;
    background: #0a3d62;
    color: #ffffff;
}

.msp-support-modal__close {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 18px;
    height: 18px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.msp-support-modal__close span {
    position: absolute;
    left: 0;
    top: 8px;
    width: 18px;
    height: 2px;
    background: #ffffff;
}

.msp-support-modal__close span:first-child {
    transform: rotate(45deg);
}

.msp-support-modal__close span:last-child {
    transform: rotate(-45deg);
}

.msp-support-modal__title {
    max-width: 640px;
    margin: 0 0 32px;
    color: #ffffff;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.msp-support-modal__content {
    color: #ffffff;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.msp-support-modal__content p,
.msp-support-modal__content ol {
    margin: 0 0 22px;
}

.msp-support-modal__content ol {
    padding-left: 24px;
}

.msp-support-modal__content li + li {
    margin-top: 12px;
}

.msp-support-modal__content a {
    color: #ffffff;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.home-contacts-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 24px;
    color: #223850;
    font-size: 14px;
    line-height: 1.6;
}

.gosuslugi-title {
    max-width: 520px;
    font-size: 26px;
    color: #fff;
}

.gosuslugi-description {
    font-size: 15px;
}

.site-footer {
    background: #f1f5f9;
}

.footer-main {
    padding: 148px 0 112px;
}

.footer-grid {
    grid-template-columns: 271px 124px 286px 229px;
    justify-content: space-between;
    gap: 0;
}

.footer-description {
    display: none;
}

.footer-nav h4,
.footer-contacts h4,
.footer-app h4 {
    display: none;
}

.footer-nav a {
    font-size: 16px;
    line-height: 22px;
    letter-spacing: -0.02em;
}

.footer-contact-item span,
.footer-contact-item a {
    font-size: 20px;
    line-height: 27px;
    letter-spacing: -0.02em;
}

.app-screenshot,
.app-screenshot-placeholder {
    width: 229px;
    height: 450px;
    min-height: 450px;
    border-radius: 4px;
    background: #fff;
}

.app-screenshot-placeholder {
    align-items: flex-start;
    justify-content: flex-start;
    padding: 28px 22px;
    border: 0;
    font-size: 22px;
    font-weight: 700;
    color: #111;
}

.footer-bottom {
    border-top: 0;
    padding: 0 0 56px;
}

.footer-bottom-inner {
    justify-content: flex-start;
}

.copyright {
    font-size: 16px;
    line-height: 22px;
    letter-spacing: -0.02em;
}

.single-post-layout,
.page-layout {
    grid-template-columns: minmax(0, 1fr) 302px;
    gap: 46px;
    justify-content: space-between;
    align-items: start;
}

.page-layout--no-sidebar {
    grid-template-columns: minmax(0, 1fr);
}

.single-post-content,
.page-content {
    background: transparent;
    border-radius: 0;
    padding: 0;
}

.single-news-section .single-post-sidebar .sidebar-widget {
    background: transparent;
    border-radius: 0;
    padding: 0;
    margin-top: 0;
}

.single-event-section .single-post-sidebar .sidebar-widget,
.single-article-section .single-post-sidebar .sidebar-widget {
    margin-top: 0;
}

.widget-title {
    font-size: 18px;
    color: #0d4672;
}

.other-news-item {
    padding-bottom: 24px;
}

.page-body,
.single-post-body {
    max-width: 862px;
    font-size: 20px;
    line-height: 32px;
    letter-spacing: -0.02em;
}

@media (max-width: 991px) {
    body.page-rekvizity .page-body,
    body.page-requisites .page-body,
    .page-content-section--requisites .page-body,
    body.page-rekvizity .page-body :where(p, li, td, th, div, span, a, strong, b, em),
    body.page-requisites .page-body :where(p, li, td, th, div, span, a, strong, b, em),
    .page-content-section--requisites .page-body :where(p, li, td, th, div, span, a, strong, b, em) {
        max-width: 100%;
        font-family: 'Open Sans', sans-serif !important;
        font-size: 16px !important;
        font-weight: 400;
        line-height: 24px !important;
        letter-spacing: -0.02em;
        color: #2C3E50;
    }
}

.events-archive-layout {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 72px;
    justify-content: space-between;
    align-items: start;
}

.events-archive-content {
    width: 100%;
    min-width: 0;
}

.events-archive-section {
    padding-bottom: 120px;
}

.events-archive-mobile-header {
    display: none;
}

.events-filter-card {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.events-filter-card .event-search-group {
    margin-bottom: 46px;
}

.events-filter-card .form-control {
    width: 100%;
    min-height: 68px;
    padding: 18px 58px 18px 32px;
    border: 0;
    border-radius: 60px;
    background-color: #ffffff;
    box-shadow: none;
}

.event-select-group .form-control {
    font-size: 18px;
    line-height: 28px;
    color: #2c3e50;
    background-position: right 32px center;
}

.event-select-group .form-control.is-native-select-hidden {
    position: absolute;
    inset: 0;
    width: 1px;
    height: 1px;
    min-height: 0;
    padding: 0;
    opacity: 0;
    pointer-events: none;
}

.event-select-custom {
    position: relative;
    z-index: 3;
}

.event-select-custom.is-open {
    z-index: 20;
}

.event-select-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 68px;
    padding: 18px 32px;
    border: 0;
    border-radius: 60px;
    background: #ffffff;
    color: #2c3e50;
    font-family: var(--font-secondary);
    font-size: 18px;
    line-height: 28px;
    letter-spacing: -0.02em;
    cursor: pointer;
    text-align: left;
}

.event-select-custom.is-open .event-select-button {
    border-radius: 34px 34px 0 0;
}

.event-select-button::after {
    content: "";
    width: 9px;
    height: 16px;
    flex: 0 0 9px;
    margin-left: 18px;
    background: url("data:image/svg+xml,%3Csvg width='9' height='16' viewBox='0 0 9 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.5 2L7.5 8L1.5 14' stroke='%232C3E50' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center center / contain no-repeat;
    transition: transform 0.2s ease;
}

.event-select-custom.is-open .event-select-button::after {
    transform: rotate(90deg);
}

.event-select-menu {
    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    right: 0;
    display: none;
    overflow: hidden;
    margin: 0;
    padding: 0 0 16px;
    list-style: none;
    background: #ffffff;
    border-radius: 0 0 28px 28px;
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.event-select-custom.is-open .event-select-menu {
    display: block;
}

.event-select-option {
    display: flex;
    align-items: center;
    min-height: 42px;
    padding: 7px 32px;
    color: #2c3e50;
    font-family: var(--font-secondary);
    font-size: 18px;
    line-height: 28px;
    letter-spacing: -0.02em;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.event-select-option:hover,
.event-select-option.is-selected {
    background-color: #f1f5f9;
    color: #0a3d62;
}

.event-search-group .form-control {
    padding-right: 76px;
    background-image: none;
}

.event-search-group::after {
    content: "";
    position: absolute;
    right: 32px;
    top: 50%;
    width: 28px;
    height: 28px;
    transform: translateY(-50%);
    pointer-events: none;
    opacity: 1;
    visibility: visible;
    background: url("data:image/svg+xml,%3Csvg width='28' height='28' viewBox='0 0 28 28' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.8333 22.1667C17.988 22.1667 22.1667 17.988 22.1667 12.8333C22.1667 7.67868 17.988 3.5 12.8333 3.5C7.67868 3.5 3.5 7.67868 3.5 12.8333C3.5 17.988 7.67868 22.1667 12.8333 22.1667Z' stroke='%232FB4BE' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M24.5 24.5L19.425 19.425' stroke='%232FB4BE' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center center / contain no-repeat;
    transition: opacity 0.2s ease, visibility 0.2s ease;
}

.event-search-group.has-value::after {
    opacity: 0;
    visibility: hidden;
}

.filter-checkbox {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 16px;
    line-height: 22px;
    color: #223850;
}

.filter-checkbox input {
    appearance: none;
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
    border: 0;
    border-radius: 50%;
    background:
        radial-gradient(circle at center, transparent 0 48%, #2fb4be 50% 100%);
    box-shadow: none;
}

.filter-checkbox input:checked {
    background: url("../images/regotkrenable.png") center center / contain no-repeat;
}

.archive-side-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-top: 42px;
}

.events-list {
    display: flex;
    flex-direction: column;
}

.event-list-item {
    display: grid;
    grid-template-columns: 190px minmax(0, 1fr) 246px;
    gap: 38px;
    padding: 36px 0;
    border-bottom: 1px solid rgba(13, 70, 114, 0.14);
    align-items: start;
}

.event-list-item.is-hidden-by-registration {
    display: none !important;
}

.event-list-date {
    display: flex;
    flex-direction: column;
    gap: 12px;
    color: #a6b2c1;
    font-size: 16px;
    line-height: 22px;
    font-weight: 600;
}

.event-list-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    white-space: nowrap;
}

.event-list-meta-icon,
.event-list-meta-item svg {
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
    object-fit: contain;
}

.event-list-meta-item svg {
    color: #2fb4be;
}

.event-list-title {
    font-size: 20px;
    line-height: 28px;
    font-weight: 600;
    letter-spacing: -0.02em;
    text-transform: none;
    margin: 0 0 14px;
}

.event-list-title a {
    color: #223850;
    text-transform: none;
}

.event-list-tag {
    margin-bottom: 18px;
    color: #35c0cf;
    font-size: 16px;
    line-height: 22px;
    font-weight: 600;
}

.event-list-excerpt {
    max-width: 520px;
    color: #9aacbb;
    font-size: 16px;
    line-height: 24px;
}

.event-list-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    justify-self: end;
    gap: 16px;
    text-align: center;
    width: 246px;
    padding-top: 0;
}

.event-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    font-size: 16px;
    line-height: 18px;
    font-weight: 700;
    text-align: center;
}

.event-status::before {
    content: "";
    width: 8px;
    height: 8px;
    flex: 0 0 8px;
    border-radius: 50%;
    background: currentColor;
}

.event-status.is-open {
    color: #27ae60;
}

.event-status.is-closed {
    color: #e74c3c;
}

.event-list-actions .btn {
    width: 246px;
    min-width: 246px;
    min-height: 68px;
    padding: 18px 24px;
    border-radius: 60px;
    font-size: 18px;
    line-height: 32px;
    font-weight: 700;
}

.documents-toolbar {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    margin: 42px 0 46px;
    flex-wrap: wrap;
}

.documents-tabs {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

.documents-tab {
    display: inline-flex;
    align-items: center;
    min-height: 68px;
    padding: 18px 32px;
    border-radius: 999px;
    background: #fff;
    color: #223850;
    box-shadow: inset 0 0 0 1px rgba(13, 70, 114, 0.06);
    font-size: 16px;
    line-height: 32px;
    letter-spacing: -0.02em;
}

.documents-tab.is-active {
    background: #35c0cf;
    color: #fff;
}

.documents-search {
    position: relative;
    width: min(100%, 320px);
}

.documents-search .form-control {
    padding-right: 72px;
}

.documents-search-submit {
    position: absolute;
    top: 50%;
    right: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    padding: 0;
    border: 0;
    background: transparent;
    transform: translateY(-50%);
}

.documents-search-submit svg {
    display: block;
    width: 28px;
    height: 28px;
}

.documents-table {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 120px;
}

.documents-table-head,
.documents-table-row {
    display: grid;
    grid-template-columns: 80px 160px 1fr 170px;
    gap: 18px;
    align-items: center;
    padding: 22px 28px;
}

.documents-table-head {
    background: #0d4672;
    color: #fff;
    font-weight: 700;
}

.documents-table-row {
    background: rgba(255, 255, 255, 0.44);
    color: #223850;
}

.documents-table-row:nth-of-type(odd) {
    background: #E8EEF3;
}

.documents-table-row:hover {
    background: rgba(255, 255, 255, 0.8);
}

.documents-table-row.is-hidden {
    display: none;
}

.documents-table-empty {
    margin: 12px 0 0;
    padding: 24px 28px;
    background: #E8EEF3;
    color: #223850;
}

.inner-page-content {
    width: 100%;
    max-width: 1310px;
}

.content-section-block {
    margin-top: 72px;
}

.content-section-title {
    margin-bottom: 42px;
    font-size: 34px;
    line-height: 54px;
    letter-spacing: -0.02em;
    color: #0d4672;
}

.content-section-title-centered {
    text-align: center;
}

.about-page-layout {
    display: grid;
    grid-template-columns: 302px minmax(0, 1fr);
    gap: 146px;
    align-items: start;
    padding-bottom: 120px;
}

.about-page-layout .page-title {
    margin-bottom: 42px;
}

.section-side-nav {
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: sticky;
    top: 20px;
}

.side-pill,
.pill-tab {
    display: inline-flex;
    align-items: center;
    width: 302px;
    min-height: 68px;
    height: 68px;
    padding: 18px 32px;
    border-radius: 999px;
    background: #fff;
    color: #223850;
    box-shadow: inset 0 0 0 1px rgba(13, 70, 114, 0.06);
    font-size: 16px;
    line-height: 32px;
    letter-spacing: -0.02em;
}

.side-pill.is-active,
.pill-tab.is-active {
    background: #2FB4BE;
    color: #fff;
}

.pill-tabs {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 42px;
}

.section-copy {
    max-width: 862px;
    font-size: 20px;
    line-height: 32px;
    letter-spacing: -0.02em;
}

.info-card-grid {
    display: grid;
    gap: 34px;
}

.info-card-grid-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.info-card-grid-3 {
    grid-template-columns: repeat(3, 414px);
}

.info-card-grid-2x2 {
    grid-template-columns: repeat(2, 414px);
}

.info-card {
    position: relative;
    width: 414px;
    min-height: 540px;
    height: 540px;
    padding: 50px;
    overflow: hidden;
    background: #fff;
    color: #223850;
}

.info-card.is-accent {
    background: #2FB4BE;
    color: #fff;
}

.info-card.is-dark {
    background: #0A3D62;
    color: #fff;
}

.info-card.is-slate,
.info-card.info-card--4.is-dark {
    background: #2C3E50;
    color: #fff;
}

.info-card h3 {
    position: absolute;
    z-index: 1;
    left: 50px;
    top: 328px;
    max-width: 328px;
    margin: 0;
    font-size: 22px;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: inherit;
}

.info-card a {
    position: absolute;
    z-index: 1;
    left: 50px;
    top: 470px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: #2FB4BE;
    font-weight: 700;
    font-size: 20px;
    line-height: 20px;
}

.info-card a::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 19px;
    background: currentColor;
    -webkit-mask: url("data:image/svg+xml,%3Csvg width='12' height='19' viewBox='0 0 12 19' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.06055 1.06067L9.06055 9.06067L1.06055 17.0607' stroke='white' stroke-width='3'/%3E%3C/svg%3E") center / contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg width='12' height='19' viewBox='0 0 12 19' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.06055 1.06067L9.06055 9.06067L1.06055 17.0607' stroke='white' stroke-width='3'/%3E%3C/svg%3E") center / contain no-repeat;
    color: currentColor;
}

.info-card:not(.is-accent):not(.is-dark):not(.is-slate) a::after {
    background: #2FB4BE;
}

.info-card.is-accent a,
.info-card.is-dark a,
.info-card.is-slate a {
    color: #fff;
}

.info-card-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 68px;
    height: 68px;
    border-radius: 50%;
    position: absolute;
    left: 50px;
    top: 50px;
    z-index: 1;
    background: #2FB4BE;
    color: #fff;
    font-size: 22px;
    line-height: 28px;
    font-weight: 600;
    letter-spacing: -0.02em;
}

.info-card.is-accent .info-card-number {
    background: #fff;
    color: #2FB4BE;
}

.info-card-art {
    position: absolute;
    top: 50px;
    right: -30px;
    width: 240px;
    height: 240px;
    pointer-events: none;
}

.info-card-art img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: brightness(0) saturate(100%) invert(95%) sepia(7%) saturate(447%) hue-rotate(176deg) brightness(101%) contrast(95%);
}

.doc-card-grid {
    display: grid;
    gap: 34px;
}

.doc-card-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-content: space-between;
}

.doc-card-grid-2 {
    grid-template-columns: repeat(2, 414px);
    justify-content: space-between;
}

.doc-link-card {
    display: flex;
    align-items: center;
    gap: 20px;
    width: 414px;
    min-height: 128px;
    height: 128px;
    padding: 32px 46px;
    background: #fff;
    color: #223850;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.doc-link-card span:last-child {
    display: -webkit-box;
    min-width: 0;
    overflow: hidden;
    font-weight: 600;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
}

.doc-link-card.is-accent {
    background: #fff;
    color: #223850;
}

.doc-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    flex: 0 0 60px;
}

.doc-link-card.is-accent .doc-icon {
    background: transparent;
}

.doc-link-card:hover,
.doc-link-card:focus-visible {
    background: #2FB4BE;
    color: #fff;
}

.doc-link-card:hover .doc-icon img,
.doc-link-card:focus-visible .doc-icon img {
    filter: brightness(0) invert(1);
}

.doc-icon.external {
    font-size: 20px;
    font-weight: 400;
}

.doc-icon img {
    display: block;
    width: 64px;
    height: 64px;
    object-fit: contain;
    max-width: none;
}

@media (max-width: 1360px) {
    .support-navigator-grid.doc-card-grid-3,
    .financial-results-grid.doc-card-grid-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .support-navigator-grid .doc-link-card,
    .financial-results-grid .doc-link-card {
        width: 100%;
    }
}

@media (max-width: 900px) {
    .support-navigator-grid.doc-card-grid-3,
    .financial-results-grid.doc-card-grid-3 {
        grid-template-columns: 1fr;
    }

    .support-navigator-category {
        margin-bottom: 56px;
    }
}

.legal-info-list,
.split-links ul {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-left: 18px;
    font-size: 18px;
    line-height: 32px;
    letter-spacing: -0.02em;
}

.legal-info-item p {
    margin: 0 0 12px;
}

.legal-info-item p:last-child {
    margin-bottom: 0;
}

.section-copy a,
.legal-info-list a,
.inner-page-content .page-body a {
    color: #2FB4BE;
}

.split-links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 46px;
}

.mup-page-section {
    padding-bottom: 120px;
}

.mup-page-section .page-title {
    margin-bottom: 60px;
}

.mup-page-section .content-section-title {
    margin-bottom: 22px;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #2C3E50;
}

.mup-page-section .split-links ul {
    gap: 0;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 40px;
    letter-spacing: -0.02em;
}

.split-links a {
    color: #2e5f8e;
}

.mup-info-link {
    padding: 0;
    border: 0;
    background: transparent;
    color: #2e5f8e;
    font: inherit;
    letter-spacing: inherit;
    text-align: left;
    cursor: pointer;
}

.mup-info-link:hover,
.mup-info-link:focus-visible {
    color: #2fb4be;
}

.mup-info-modal-open {
    overflow: hidden;
}

.mup-info-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
}

.mup-info-modal.is-open {
    display: flex;
}

.mup-info-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.62);
}

.mup-info-modal__dialog {
    position: relative;
    width: min(862px, 100%);
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    padding: 60px 70px;
    background: #0a3d62;
    color: #ffffff;
}

.mup-info-modal__close {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 18px;
    height: 18px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.mup-info-modal__close span {
    position: absolute;
    left: 0;
    top: 8px;
    width: 18px;
    height: 2px;
    background: #ffffff;
}

.mup-info-modal__close span:first-child {
    transform: rotate(45deg);
}

.mup-info-modal__close span:last-child {
    transform: rotate(-45deg);
}

.mup-info-modal__title {
    max-width: 640px;
    margin: 0 0 32px;
    color: #ffffff;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.mup-info-modal__content {
    color: #ffffff;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.mup-info-modal__content p,
.mup-info-modal__content ol,
.mup-info-modal__content ul {
    margin: 0 0 22px;
}

.mup-info-modal__content p:last-child,
.mup-info-modal__content ol:last-child,
.mup-info-modal__content ul:last-child {
    margin-bottom: 0;
}

.mup-info-modal__content ol,
.mup-info-modal__content ul {
    padding-left: 24px;
}

.mup-info-modal__content li + li {
    margin-top: 12px;
}

.mup-info-modal__content a {
    color: #ffffff;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.contact-info-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 32px;
    margin-bottom: 42px;
}

.contact-simple-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    color: #223850;
    font-size: 20px;
    line-height: 32px;
    letter-spacing: -0.02em;
}

.contact-simple-item {
    display: flex;
    align-items: center;
    gap: 24px;
}

.contact-simple-item img {
    display: block;
    width: 28px;
    height: 28px;
    object-fit: contain;
    flex: 0 0 28px;
}

.contact-section-button {
    width: 414px;
    height: 68px;
    min-height: 68px;
    padding: 18px 40px;
    border-radius: 60px;
    justify-content: center;
    align-self: flex-start;
    margin-top: 6px;
    font-size: 18px;
    line-height: 32px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.map-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 862px;
    max-width: 100%;
    height: 342px;
    min-height: 342px;
    background: linear-gradient(135deg, rgba(53, 192, 207, 0.12), rgba(13, 70, 114, 0.08));
    color: #6f8498;
    overflow: hidden;
}

.map-placeholder iframe,
.map-placeholder-image {
    display: block;
    width: 100%;
    height: 342px;
    min-height: 342px;
    border: 0;
}

.map-placeholder-image {
    object-fit: cover;
}

@media (max-width: 1279px) {
    .news-section .news-grid,
    .directions-grid,
    .partners-section .partners-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .news-card,
    .direction-card,
    .partner-card {
        width: 100%;
    }

    .contact-form-wrapper,
    .newsletter-content,
    .gosuslugi-content {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .contact-form-container,
    .newsletter-form-container,
    .home-contacts-card {
        width: 100%;
        max-width: 638px;
        transform: none;
    }

    .gosuslugi-image img {
        width: 100%;
        max-width: 929px;
    }

    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid {
        max-width: 100%;
        padding: 0 24px;
    }

    .gosuslugi-section {
        height: auto;
        min-height: 0;
        padding: 110px 0;
    }

    .gosuslugi-content {
        display: grid;
        grid-template-columns: 1fr;
        gap: 40px;
        min-height: 0;
    }

    .gosuslugi-info {
        max-width: 100%;
    }

    .gosuslugi-image {
        position: static;
        width: 100%;
        height: auto;
        transform: none;
        right: auto;
    }

    .partner-strip-list {
        flex-wrap: wrap;
        justify-content: center;
    }

    .partner-strip-item {
        flex: 0 1 220px;
    }

    .hero-content {
        width: calc(100% - 520px);
        padding: 184px 40px 96px;
    }

    .hero-slider {
        width: calc(100% - 532px);
    }

    .hero-title {
        font-size: 40px;
        line-height: 48px;
        max-width: 620px;
    }

    .hero-sidebar {
        width: 532px;
        height: auto;
    }

    .hero-sidebar-card {
        width: 520px;
        padding: 0 48px;
    }

    .header-contacts {
        gap: 14px;
    }

    .main-navigation ul {
        gap: 24px;
    }

    .footer-grid {
        grid-template-columns: 1fr 0.8fr 1fr 200px;
    }
}

@media (max-width: 1100px) {
    .hero-slider {
        width: 100%;
    }

    .hero-content {
        width: 100%;
        padding-right: 40px;
    }

    .hero-sidebar {
        position: static;
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .hero-sidebar-card {
        width: 50%;
    }

    .events-archive-layout,
    .about-page-layout,
    .single-post-layout,
    .page-layout {
        grid-template-columns: 1fr;
    }

    .section-side-nav {
        position: static;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .footer-grid,
    .newsletter-content,
    .info-card-grid-4,
    .info-card-grid-3,
    .doc-card-grid-3,
    .split-links,
    .partner-strip-list,
    .cooperation-grid,
    .reporting-grid,
    .msp-support-grid,
    .info-card-grid-3,
    .info-card-grid-2x2 {
        grid-template-columns: 1fr 1fr;
    }

    .reporting-card,
    .msp-support-card {
        width: 100%;
    }
}

@media (max-width: 991px) {
    .contact-modal {
        padding: 32px 16px;
    }

    .contact-modal__dialog {
        width: 100%;
        min-height: 0;
        padding: 54px 24px 40px;
    }

    .contact-modal__title {
        font-size: 22px;
        line-height: 40px;
        margin-bottom: 24px;
    }

    .contact-modal__description {
        width: 270px;
		margin-bottom: 38px;
        font-size: 16px;
        line-height: 28px;
    }

    .contact-modal__row,
    .contact-modal__actions {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .contact-modal__message,
    .contact-modal__actions .btn {
        width: 100%;
    }

    .contact-modal__actions {
        margin-top: 28px;
    }

    .news-section .news-grid,
    .directions-grid,
    .partners-section .partners-grid {
        grid-template-columns: 1fr;
    }

    .header-top-inner {
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .header-logo {
        min-width: 220px;
    }

    .header-main {
        width: 100%;
        order: 3;
        align-items: stretch;
    }

    .header-utility {
        flex-wrap: wrap;
        justify-content: flex-start;
        gap: 16px;
    }

    .header-search {
        width: 100%;
        max-width: 320px;
    }

    .header-nav-row {
        justify-content: space-between;
    }

    .main-navigation ul {
        gap: 18px;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .news-grid,
    .blog-list-grid,
    .archive-list-grid,
    .partners-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .directions-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .contact-form-wrapper,
    .gosuslugi-content {
        grid-template-columns: 1fr;
    }

    .gosuslugi-section {
        height: auto;
        min-height: 0;
        padding: 96px 0;
    }

    .home-contacts-card {
        width: min(100%, 360px);
    }

    .hero-section {
        height: auto;
        padding-bottom: 64px;
    }

    .hero-slider,
    .hero-slide,
    .hero-slide.active {
        min-height: 526px;
    }

    .hero-slider {
        width: calc(100% - 402px);
    }

    .hero-content {
        width: calc(100% - 402px);
        padding: 0 34px 72px;
        align-items: flex-end;
    }

    .hero-title {
        max-width: 360px;
        font-size: 21px;
        line-height: 1.1;
        margin-bottom: 18px;
    }

    .hero-slider-controls {
        left: 250px;
        bottom: 44px;
        gap: 12px;
    }

    .hero-dot {
        width: 8px;
        height: 8px;
    }

    .hero-arrow {
        width: 32px;
        height: 32px;
    }

    .hero-sidebar {
        top: 0;
        width: 402px;
        height: 100%;
        gap: 0;
        padding-left: 12px;
    }

    .hero-sidebar-card {
        width: 390px;
        height: 131px;
        padding: 0 32px;
        gap: 18px;
    }

    .hero-sidebar-icon,
    .hero-sidebar-icon svg {
        width: 52px;
        height: 52px;
    }

    .hero-sidebar-title {
        font-size: 13px;
        line-height: 1.25;
        max-width: 190px;
        letter-spacing: -0.01em;
    }
}

@media (max-width: 768px) {
    .header-top {
        padding: 24px 0;
    }

    .header-top-inner {
        align-items: flex-start;
        gap: 16px;
    }

    .header-main {
        gap: 12px;
    }

    .header-utility {
        display: none;
    }

    .header-nav-row {
        justify-content: flex-end;
    }

    .main-navigation {
        display: none;
        order: 3;
        width: 100%;
        background: #ffffff;
        border-radius: 28px;
        padding: 20px;
        box-shadow: 0 14px 40px rgba(10, 61, 98, 0.12);
    }

    .main-navigation ul,
    .hero-sidebar {
        display: none;
    }

    .main-navigation.active {
        display: block;
    }

    .main-navigation.active ul {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
        padding: 0;
    }

    .main-navigation.active .sub-menu {
        display: block;
        position: static;
        min-width: 100%;
        box-shadow: none;
        padding: 10px 0 0 14px;
        background: transparent;
    }

    .main-navigation.active a {
        padding: 0;
    }

    .header-drawer-meta {
        display: none;
    }

    .main-navigation.active .header-drawer-meta {
        display: flex;
        flex-direction: column;
        gap: 18px;
        margin-top: 22px;
        padding-top: 18px;
        border-top: 1px solid rgba(12, 70, 115, 0.12);
    }

    .mobile-menu-toggle {
        position: static;
        margin-left: 0;
    }

    .header-search {
        max-width: 100%;
    }

    .header-contacts {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .hero-content,
    .hero-slider-controls {
        left: 16px;
        padding-left: 0;
    }

    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid {
        padding: 0 16px;
    }

    .footer-grid,
    .newsletter-content,
    .info-card-grid-4,
    .info-card-grid-3,
    .doc-card-grid-3,
    .doc-card-grid-2,
    .info-card-grid-2x2,
    .split-links,
    .partner-strip-list,
    .cooperation-grid,
    .reporting-grid,
    .msp-support-grid,
    .info-card-grid-3,
    .info-card-grid-2x2,
    .documents-table-head,
    .documents-table-row {
        grid-template-columns: 1fr;
    }

    .event-list-item,
    .events-archive-layout {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .documents-toolbar,
    .contact-info-row,
    .form-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .news-grid,
    .blog-list-grid,
    .archive-list-grid,
    .partners-grid,
    .directions-grid {
        grid-template-columns: 1fr;
    }

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

    .hero-content {
        padding: 110px 16px 82px;
    }
}

.single-lead-title {
    margin-bottom: 28px;
    font-size: 22px;
    line-height: 1.3;
    color: #223850;
}

.event-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 28px;
}

.event-meta-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.event-meta-item span {
    color: #5ebdca;
    font-size: 13px;
}

.event-meta-item strong {
    font-size: 18px;
    color: #223850;
}

.event-register-btn {
    min-width: 320px;
}

.partners-grid-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 768px) {
    .event-meta-grid,
    .partners-grid-compact {
        grid-template-columns: 1fr;
    }

    .event-register-btn {
        min-width: 0;
        width: 100%;
    }

    .msp-support-modal,
    .mup-info-modal {
        padding: 20px 14px;
    }

    .msp-support-modal__dialog,
    .mup-info-modal__dialog {
        max-height: calc(100vh - 40px);
        padding: 50px 24px 34px;
    }

    .msp-support-modal__title,
    .mup-info-modal__title {
        font-size: 22px;
        line-height: 28px;
    }

    .msp-support-modal__content,
    .mup-info-modal__content {
        font-size: 16px;
        line-height: 24px;
    }
}

/* ==========================================================================
   Доступность и служебные страницы
   ========================================================================== */

.accessibility-panel {
    display: none;
    background: #fff;
    color: #000;
    border-bottom: 2px solid #000;
    position: relative;
    z-index: 1200;
}

.accessibility-panel.is-active {
    display: block;
}

.accessibility-panel__inner {
    padding: 18px 0 24px;
}

.accessibility-panel__toolbar,
.accessibility-panel__settings {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 28px;
}

.accessibility-panel__toolbar {
    align-items: center;
    justify-content: space-between;
}

.accessibility-panel__group,
.accessibility-panel__setting-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.accessibility-panel__settings {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid #d9d9d9;
}

.accessibility-panel__settings.is-collapsed {
    display: none;
}

.accessibility-panel__settings-col {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.accessibility-panel__settings-col--schemes {
    flex: 1 1 640px;
}

.accessibility-panel__toolbar-actions,
.accessibility-panel__footer-actions,
.accessibility-panel__controls {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.accessibility-panel__label,
.accessibility-panel__setting-label {
    font-size: 18px;
    line-height: 1.3;
    font-weight: 400;
    color: inherit;
}

.accessibility-panel__heading {
    margin: 0;
    font-size: 26px;
    line-height: 1.3;
    font-weight: 700;
    color: inherit;
}

.accessibility-panel__chip,
.accessibility-panel__link,
.accessibility-panel__action,
.accessibility-panel__scheme {
    appearance: none;
    border: 2px solid currentColor;
    background: transparent;
    color: inherit;
    cursor: pointer;
    text-decoration: none;
    font-family: inherit;
}

.accessibility-panel__chip,
.accessibility-panel__link,
.accessibility-panel__action {
    min-height: 42px;
    padding: 8px 14px;
    font-size: 18px;
    line-height: 1.2;
}

.accessibility-panel__chip[aria-pressed="true"],
.accessibility-panel__chip.is-active,
.accessibility-panel__link:hover,
.accessibility-panel__action:hover {
    background: #000;
    color: #fff;
}

.accessibility-panel__chip[data-accessibility-font-size="normal"] {
    font-size: 20px;
}

.accessibility-panel__chip[data-accessibility-font-size="large"] {
    font-size: 24px;
}

.accessibility-panel__chip[data-accessibility-font-size="xlarge"] {
    font-size: 28px;
}

.accessibility-panel__chip--scheme[data-accessibility-scheme="bw"] {
    background: #fff;
    color: #000;
}

.accessibility-panel__chip--scheme[data-accessibility-scheme="wb"] {
    background: #000;
    color: #fff;
}

.accessibility-panel__chip--scheme[data-accessibility-scheme="blue"] {
    background: #9dd1ff;
    color: #063462;
}

.accessibility-panel__chip--scheme[data-accessibility-scheme="beige"] {
    background: #f7f1d2;
    color: #4a2c12;
}

.accessibility-panel__chip--scheme[data-accessibility-scheme="green"] {
    background: #47311a;
    color: #b5ff3b;
}

.accessibility-panel__scheme-list {
    display: grid;
    gap: 8px;
}

.accessibility-panel__scheme {
    width: 100%;
    padding: 14px 18px;
    text-align: left;
    font-size: 18px;
    line-height: 1.3;
    font-weight: 700;
}

.accessibility-panel__scheme.is-active {
    outline: 3px solid #000;
    outline-offset: 2px;
}

.accessibility-panel__scheme--bw {
    background: #fff;
    color: #000;
}

.accessibility-panel__scheme--wb {
    background: #000;
    color: #fff;
}

.accessibility-panel__scheme--blue {
    background: #9dd1ff;
    color: #063462;
}

.accessibility-panel__scheme--beige {
    background: #f7f1d2;
    color: #4a2c12;
}

.accessibility-panel__scheme--green {
    background: #47311a;
    color: #b5ff3b;
}

.accessibility-mode {
    --upriu-a11y-bg: #ffffff;
    --upriu-a11y-bg-soft: #f2f2f2;
    --upriu-a11y-text: #000000;
    --upriu-a11y-accent: #000000;
    --upriu-a11y-border: #000000;
    --upriu-a11y-link: #000000;
    --upriu-a11y-heading: #000000;
    --upriu-a11y-panel-bg: #ffffff;
    background: var(--upriu-a11y-bg) !important;
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode[data-accessibility-scheme="wb"] {
    --upriu-a11y-bg: #000000;
    --upriu-a11y-bg-soft: #111111;
    --upriu-a11y-text: #ffffff;
    --upriu-a11y-accent: #ffffff;
    --upriu-a11y-border: #ffffff;
    --upriu-a11y-link: #ffffff;
    --upriu-a11y-heading: #ffffff;
    --upriu-a11y-panel-bg: #000000;
}

.accessibility-mode[data-accessibility-scheme="blue"] {
    --upriu-a11y-bg: #9dd1ff;
    --upriu-a11y-bg-soft: #b9ddff;
    --upriu-a11y-text: #063462;
    --upriu-a11y-accent: #063462;
    --upriu-a11y-border: #063462;
    --upriu-a11y-link: #063462;
    --upriu-a11y-heading: #063462;
    --upriu-a11y-panel-bg: #9dd1ff;
}

.accessibility-mode[data-accessibility-scheme="beige"] {
    --upriu-a11y-bg: #f7f1d2;
    --upriu-a11y-bg-soft: #efe4bb;
    --upriu-a11y-text: #4a2c12;
    --upriu-a11y-accent: #4a2c12;
    --upriu-a11y-border: #4a2c12;
    --upriu-a11y-link: #4a2c12;
    --upriu-a11y-heading: #4a2c12;
    --upriu-a11y-panel-bg: #f7f1d2;
}

.accessibility-mode[data-accessibility-scheme="green"] {
    --upriu-a11y-bg: #47311a;
    --upriu-a11y-bg-soft: #5a3c1f;
    --upriu-a11y-text: #b5ff3b;
    --upriu-a11y-accent: #b5ff3b;
    --upriu-a11y-border: #b5ff3b;
    --upriu-a11y-link: #b5ff3b;
    --upriu-a11y-heading: #b5ff3b;
    --upriu-a11y-panel-bg: #47311a;
}

.accessibility-mode[data-accessibility-font="tahoma"] {
    font-family: Tahoma, Arial, sans-serif !important;
}

.accessibility-mode[data-accessibility-font="times"] {
    font-family: "Times New Roman", Times, serif !important;
}

.accessibility-mode[data-accessibility-font="arial"] {
    font-family: Arial, Helvetica, sans-serif !important;
}

.accessibility-mode[data-accessibility-spacing="medium"] {
    letter-spacing: 0.06em !important;
}

.accessibility-mode[data-accessibility-spacing="wide"] {
    letter-spacing: 0.12em !important;
}

.accessibility-mode[data-accessibility-font-size="normal"] {
    font-size: 18px !important;
}

.accessibility-mode[data-accessibility-font-size="large"] {
    font-size: 22px !important;
}

.accessibility-mode[data-accessibility-font-size="xlarge"] {
    font-size: 26px !important;
}

.accessibility-mode[data-accessibility-font-size="normal"] p,
.accessibility-mode[data-accessibility-font-size="normal"] li,
.accessibility-mode[data-accessibility-font-size="normal"] a,
.accessibility-mode[data-accessibility-font-size="normal"] button,
.accessibility-mode[data-accessibility-font-size="normal"] input,
.accessibility-mode[data-accessibility-font-size="normal"] textarea,
.accessibility-mode[data-accessibility-font-size="normal"] select,
.accessibility-mode[data-accessibility-font-size="normal"] label,
.accessibility-mode[data-accessibility-font-size="normal"] td,
.accessibility-mode[data-accessibility-font-size="normal"] th {
    font-size: 18px !important;
    line-height: 1.7 !important;
}

.accessibility-mode[data-accessibility-font-size="large"] p,
.accessibility-mode[data-accessibility-font-size="large"] li,
.accessibility-mode[data-accessibility-font-size="large"] a,
.accessibility-mode[data-accessibility-font-size="large"] button,
.accessibility-mode[data-accessibility-font-size="large"] input,
.accessibility-mode[data-accessibility-font-size="large"] textarea,
.accessibility-mode[data-accessibility-font-size="large"] select,
.accessibility-mode[data-accessibility-font-size="large"] label,
.accessibility-mode[data-accessibility-font-size="large"] td,
.accessibility-mode[data-accessibility-font-size="large"] th {
    font-size: 22px !important;
    line-height: 1.75 !important;
}

.accessibility-mode[data-accessibility-font-size="xlarge"] p,
.accessibility-mode[data-accessibility-font-size="xlarge"] li,
.accessibility-mode[data-accessibility-font-size="xlarge"] a,
.accessibility-mode[data-accessibility-font-size="xlarge"] button,
.accessibility-mode[data-accessibility-font-size="xlarge"] input,
.accessibility-mode[data-accessibility-font-size="xlarge"] textarea,
.accessibility-mode[data-accessibility-font-size="xlarge"] select,
.accessibility-mode[data-accessibility-font-size="xlarge"] label,
.accessibility-mode[data-accessibility-font-size="xlarge"] td,
.accessibility-mode[data-accessibility-font-size="xlarge"] th {
    font-size: 26px !important;
    line-height: 1.8 !important;
}

.accessibility-mode .site-header,
.accessibility-mode .site-footer,
.accessibility-mode .fullscreen-menu,
.accessibility-mode .newsletter-section,
.accessibility-mode .complaints-section,
.accessibility-mode .contact-modal__dialog,
.accessibility-mode .consumer-market-modal__dialog,
.accessibility-mode .msp-support-modal__dialog,
.accessibility-mode .documents-table-head,
.accessibility-mode .documents-table-row,
.accessibility-mode .hero-sidebar-card,
.accessibility-mode .news-card,
.accessibility-mode .partner-card,
.accessibility-mode .doc-link-card,
.accessibility-mode .info-card,
.accessibility-mode .side-pill,
.accessibility-mode .pill-tab,
.accessibility-mode .event-card,
.accessibility-mode .single-news-sidebar .news-card,
.accessibility-mode .archive-news-card,
.accessibility-mode .archive-events-list__item,
.accessibility-mode .footer-main,
.accessibility-mode .footer-bottom {
    background: var(--upriu-a11y-bg) !important;
    color: var(--upriu-a11y-text) !important;
    border-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode a,
.accessibility-mode .page-title,
.accessibility-mode .section-title,
.accessibility-mode .section-heading,
.accessibility-mode .main-navigation a,
.accessibility-mode .site-header a,
.accessibility-mode .site-footer a,
.accessibility-mode .footer-contact-value,
.accessibility-mode .footer-contact-label,
.accessibility-mode .section-copy a,
.accessibility-mode .entry-content a {
    color: var(--upriu-a11y-link) !important;
}

.accessibility-mode h1,
.accessibility-mode h2,
.accessibility-mode h3,
.accessibility-mode h4,
.accessibility-mode h5,
.accessibility-mode h6,
.accessibility-mode .logo-title,
.accessibility-mode .logo-subtitle {
    color: var(--upriu-a11y-heading) !important;
}

.accessibility-mode .btn,
.accessibility-mode button,
.accessibility-mode input,
.accessibility-mode textarea,
.accessibility-mode select,
.accessibility-mode .search-field,
.accessibility-mode .search-submit,
.accessibility-mode .mobile-menu-toggle,
.accessibility-mode .hero-arrow,
.accessibility-mode .contact-ui-icon,
.accessibility-mode .header-contact-icon,
.accessibility-mode .footer-contact-item {
    border-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode .btn,
.accessibility-mode .search-submit,
.accessibility-mode .hero-arrow,
.accessibility-mode .mobile-menu-toggle,
.accessibility-mode .hero-dot.active,
.accessibility-mode .pill-tab.is-active,
.accessibility-mode .side-pill.is-active {
    background: var(--upriu-a11y-accent) !important;
    color: var(--upriu-a11y-bg) !important;
}

.accessibility-mode .logo-full img,
.accessibility-mode .logo-icon img,
.accessibility-mode .header-contact-icon,
.accessibility-mode .contact-ui-icon {
    filter: none !important;
}

.accessibility-mode[data-accessibility-images="off"] img,
.accessibility-mode[data-accessibility-images="off"] .hero-slide-bg,
.accessibility-mode[data-accessibility-images="off"] .hero-image,
.accessibility-mode[data-accessibility-images="off"] .newsletter-artwork,
.accessibility-mode[data-accessibility-images="off"] .newsletter-logo-art,
.accessibility-mode[data-accessibility-images="off"] .complaints-artwork,
.accessibility-mode[data-accessibility-images="off"] .contact-map-image,
.accessibility-mode[data-accessibility-images="off"] .page-featured-image,
.accessibility-mode[data-accessibility-images="off"] .news-card-thumb,
.accessibility-mode[data-accessibility-images="off"] .news-card-image,
.accessibility-mode[data-accessibility-images="off"] .single-post-featured,
.accessibility-mode[data-accessibility-images="off"] .hero-slide::before,
.accessibility-mode[data-accessibility-images="off"] .hero-slide::after,
.accessibility-mode[data-accessibility-images="off"] .newsletter-section::before,
.accessibility-mode[data-accessibility-images="off"] .newsletter-section::after {
    display: none !important;
    background-image: none !important;
}

.accessibility-mode[data-accessibility-images="on"] img,
.accessibility-mode[data-accessibility-images="on"] .hero-slide-bg {
    display: block;
}

.accessibility-mode,
.accessibility-mode body,
.accessibility-mode .site-main,
.accessibility-mode .page-wrapper,
.accessibility-mode .content-area,
.accessibility-mode .site-content,
.accessibility-mode main,
.accessibility-mode section,
.accessibility-mode article,
.accessibility-mode aside {
    background: var(--upriu-a11y-bg) !important;
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode,
.accessibility-mode * {
    scroll-behavior: auto !important;
}

.accessibility-mode *,
.accessibility-mode *::before,
.accessibility-mode *::after {
    box-shadow: none !important;
    text-shadow: none !important;
}

.accessibility-mode .site-header,
.accessibility-mode .site-footer,
.accessibility-mode .footer-home-style,
.accessibility-mode .page-header,
.accessibility-mode .page-content-section,
.accessibility-mode .archive-list-section,
.accessibility-mode .single-post-section,
.accessibility-mode .single-event-section,
.accessibility-mode .single-article-section,
.accessibility-mode .documents-page-section,
.accessibility-mode .reporting-section,
.accessibility-mode .consumer-page-content,
.accessibility-mode .support-navigator-section,
.accessibility-mode .msp-support-section,
.accessibility-mode .cooperation-page-section,
.accessibility-mode .contact-form-section,
.accessibility-mode .newsletter-section,
.accessibility-mode .complaints-section,
.accessibility-mode .partners-section,
.accessibility-mode .contacts-map-section,
.accessibility-mode .home-contacts-section {
    background: var(--upriu-a11y-bg) !important;
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode .hero-section,
.accessibility-mode .hero-slider,
.accessibility-mode .hero-slide,
.accessibility-mode .hero-content,
.accessibility-mode .hero-sidebar,
.accessibility-mode .hero-overlay,
.accessibility-mode .hero-bg-placeholder {
    background: var(--upriu-a11y-bg-soft) !important;
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode .hero-content,
.accessibility-mode .single-post-sidebar .sidebar-widget,
.accessibility-mode .single-event-sidebar .sidebar-widget,
.accessibility-mode .page-sidebar,
.accessibility-mode .events-filter-card,
.accessibility-mode .documents-toolbar,
.accessibility-mode .feedback-form,
.accessibility-mode .contact-form-container,
.accessibility-mode .newsletter-form-container,
.accessibility-mode .home-contacts-card,
.accessibility-mode .contact-modal__dialog,
.accessibility-mode .consumer-market-modal__dialog,
.accessibility-mode .msp-support-modal__dialog,
.accessibility-mode .fullscreen-menu {
    border: 2px solid var(--upriu-a11y-border) !important;
}

.accessibility-mode .hero-sidebar-card,
.accessibility-mode .news-card,
.accessibility-mode .partner-card,
.accessibility-mode .doc-link-card,
.accessibility-mode .info-card,
.accessibility-mode .side-pill,
.accessibility-mode .pill-tab,
.accessibility-mode .event-card,
.accessibility-mode .archive-news-card,
.accessibility-mode .archive-events-list__item,
.accessibility-mode .documents-table-head,
.accessibility-mode .documents-table-row,
.accessibility-mode .cooperation-card,
.accessibility-mode .reporting-card,
.accessibility-mode .consumer-market-card,
.accessibility-mode .msp-support-card,
.accessibility-mode .contact-modal__dialog,
.accessibility-mode .consumer-market-modal__dialog,
.accessibility-mode .msp-support-modal__dialog,
.accessibility-mode .footer-main,
.accessibility-mode .footer-bottom {
    border-width: 2px !important;
    border-style: solid !important;
}

.accessibility-mode .news-card:hover,
.accessibility-mode .partner-card:hover,
.accessibility-mode .quick-link-card:hover,
.accessibility-mode .cooperation-card:hover,
.accessibility-mode .msp-support-card:hover,
.accessibility-mode .hero-sidebar-card:hover,
.accessibility-mode .other-news-card.news-card:hover {
    transform: none !important;
}

.accessibility-mode a {
    text-decoration: underline !important;
    text-decoration-thickness: 2px !important;
    text-underline-offset: 0.16em !important;
}

.accessibility-mode .btn,
.accessibility-mode button,
.accessibility-mode .search-submit,
.accessibility-mode .mobile-menu-toggle,
.accessibility-mode .hero-arrow,
.accessibility-mode .hero-sidebar-card,
.accessibility-mode .pill-tab,
.accessibility-mode .side-pill,
.accessibility-mode .page-numbers,
.accessibility-mode .documents-tab,
.accessibility-mode .reporting-card-link,
.accessibility-mode .cooperation-card-link,
.accessibility-mode .consumer-market-card-link,
.accessibility-mode .msp-support-card-link,
.accessibility-mode .direction-link,
.accessibility-mode .info-card a,
.accessibility-mode .contact-modal__close,
.accessibility-mode .consumer-market-modal__close,
.accessibility-mode .msp-support-modal__close {
    text-decoration: none !important;
}

.accessibility-mode .btn,
.accessibility-mode button,
.accessibility-mode .search-submit,
.accessibility-mode .mobile-menu-toggle,
.accessibility-mode .hero-arrow,
.accessibility-mode .page-numbers,
.accessibility-mode .documents-tab,
.accessibility-mode .pill-tab,
.accessibility-mode .side-pill {
    border: 2px solid var(--upriu-a11y-border) !important;
}

.accessibility-mode .btn:not(.btn--secondary),
.accessibility-mode .search-submit,
.accessibility-mode .mobile-menu-toggle,
.accessibility-mode .hero-arrow,
.accessibility-mode .hero-dot.active,
.accessibility-mode .pill-tab.is-active,
.accessibility-mode .side-pill.is-active,
.accessibility-mode .documents-tab.is-active,
.accessibility-mode .pagination .page-numbers.current {
    background: var(--upriu-a11y-accent) !important;
    color: var(--upriu-a11y-bg) !important;
}

.accessibility-mode .btn--secondary,
.accessibility-mode .page-numbers,
.accessibility-mode .documents-tab,
.accessibility-mode .pill-tab,
.accessibility-mode .side-pill,
.accessibility-mode .search-field,
.accessibility-mode .form-control,
.accessibility-mode input,
.accessibility-mode textarea,
.accessibility-mode select {
    background: var(--upriu-a11y-bg-soft) !important;
    color: var(--upriu-a11y-text) !important;
    border-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode input::placeholder,
.accessibility-mode textarea::placeholder,
.accessibility-mode .search-field::placeholder,
.accessibility-mode .form-control::placeholder {
    color: var(--upriu-a11y-text) !important;
    opacity: 0.75 !important;
}

.accessibility-mode .btn:hover,
.accessibility-mode button:hover,
.accessibility-mode .search-submit:hover,
.accessibility-mode .mobile-menu-toggle:hover,
.accessibility-mode .hero-arrow:hover,
.accessibility-mode .page-numbers:hover,
.accessibility-mode .documents-tab:hover,
.accessibility-mode .pill-tab:hover,
.accessibility-mode .side-pill:hover,
.accessibility-mode .cooperation-card-link:hover,
.accessibility-mode .reporting-card-link:hover,
.accessibility-mode .consumer-market-card-link:hover,
.accessibility-mode .msp-support-card-link:hover,
.accessibility-mode .direction-link:hover,
.accessibility-mode .info-card a:hover {
    background: var(--upriu-a11y-accent) !important;
    color: var(--upriu-a11y-bg) !important;
    border-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode :focus,
.accessibility-mode :focus-visible,
.accessibility-mode button:focus,
.accessibility-mode a:focus,
.accessibility-mode input:focus,
.accessibility-mode textarea:focus,
.accessibility-mode select:focus {
    outline: 3px solid var(--upriu-a11y-accent) !important;
    outline-offset: 3px !important;
}

.accessibility-mode .main-navigation a,
.accessibility-mode .header-contact-item a,
.accessibility-mode .header-contact-item span,
.accessibility-mode .footer-nav a,
.accessibility-mode .footer-contact-value,
.accessibility-mode .footer-contact-label,
.accessibility-mode .breadcrumbs,
.accessibility-mode .breadcrumbs a,
.accessibility-mode .news-card-title a,
.accessibility-mode .news-card-category,
.accessibility-mode .event-card-tag,
.accessibility-mode .single-event-meta-value,
.accessibility-mode .single-event-resource-link,
.accessibility-mode .documents-table a,
.accessibility-mode .consumer-market-modal__list a,
.accessibility-mode .msp-support-modal__content a,
.accessibility-mode .entry-content a,
.accessibility-mode .section-copy a {
    color: var(--upriu-a11y-link) !important;
}

.accessibility-mode .header-contact-item svg,
.accessibility-mode .footer-contact-item svg,
.accessibility-mode .search-submit svg,
.accessibility-mode .hero-arrow svg,
.accessibility-mode .news-card-date svg,
.accessibility-mode .event-card-date svg,
.accessibility-mode .event-card-time svg,
.accessibility-mode .single-event-meta svg,
.accessibility-mode .consumer-market-card-link svg,
.accessibility-mode .reporting-card-link svg,
.accessibility-mode .cooperation-card-link svg,
.accessibility-mode .msp-support-card-link svg,
.accessibility-mode .direction-link svg,
.accessibility-mode .info-card a svg {
    color: var(--upriu-a11y-accent) !important;
    fill: currentColor !important;
    stroke: currentColor !important;
}

.accessibility-mode .documents-table-head {
    background: var(--upriu-a11y-accent) !important;
    color: var(--upriu-a11y-bg) !important;
}

.accessibility-mode .documents-table-row:nth-of-type(odd),
.accessibility-mode .documents-table-empty,
.accessibility-mode .archive-events-list__item:nth-of-type(odd),
.accessibility-mode .archive-news-card:nth-of-type(odd) {
    background: var(--upriu-a11y-bg-soft) !important;
}

.accessibility-mode .documents-table-row:hover,
.accessibility-mode .archive-events-list__item:hover,
.accessibility-mode .archive-news-card:hover {
    background: var(--upriu-a11y-bg-soft) !important;
}

.accessibility-mode .contact-modal__backdrop,
.accessibility-mode .consumer-market-modal__backdrop,
.accessibility-mode .msp-support-modal__backdrop {
    background: rgba(0, 0, 0, 0.8) !important;
}

.accessibility-mode .contact-modal__dialog,
.accessibility-mode .consumer-market-modal__dialog,
.accessibility-mode .msp-support-modal__dialog,
.accessibility-mode .contact-modal__form .form-control,
.accessibility-mode .consumer-market-modal__download,
.accessibility-mode .msp-support-modal__content {
    background: var(--upriu-a11y-bg) !important;
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode .contact-modal__close span,
.accessibility-mode .consumer-market-modal__close span,
.accessibility-mode .msp-support-modal__close span {
    background: var(--upriu-a11y-text) !important;
}

.accessibility-mode .logo-full img,
.accessibility-mode .logo-icon img,
.accessibility-mode .hero-sidebar-icon img,
.accessibility-mode .cooperation-card-icon img,
.accessibility-mode .reporting-card-icon img,
.accessibility-mode .doc-icon img,
.accessibility-mode .partner-logo,
.accessibility-mode .footer-home-logo .logo-icon img {
    filter: none !important;
}

.accessibility-mode .partner-logo,
.accessibility-mode .footer-home-logo .logo-icon img,
.accessibility-mode .site-logo img {
    max-width: 100% !important;
    object-fit: contain !important;
}

.accessibility-mode[data-accessibility-images="off"] .hero-overlay,
.accessibility-mode[data-accessibility-images="off"] .info-card-art,
.accessibility-mode[data-accessibility-images="off"] .direction-card-art,
.accessibility-mode[data-accessibility-images="off"] .newsletter-section::before,
.accessibility-mode[data-accessibility-images="off"] .newsletter-section::after,
.accessibility-mode[data-accessibility-images="off"] .complaints-section::before,
.accessibility-mode[data-accessibility-images="off"] .complaints-section::after,
.accessibility-mode[data-accessibility-images="off"] .footer-app img,
.accessibility-mode[data-accessibility-images="off"] .partner-logo,
.accessibility-mode[data-accessibility-images="off"] .site-logo img {
    display: none !important;
}

.accessibility-mode[data-accessibility-images="off"] .hero-section,
.accessibility-mode[data-accessibility-images="off"] .hero-slider,
.accessibility-mode[data-accessibility-images="off"] .hero-slide {
    min-height: auto !important;
    background: var(--upriu-a11y-bg-soft) !important;
}

.accessibility-mode .newsletter-disclaimer,
.accessibility-mode .form-disclaimer,
.accessibility-mode .footer-home-style .footer-contact-label,
.accessibility-mode .footer-home-style .logo-subtitle,
.accessibility-mode .news-card-date,
.accessibility-mode .event-card-date,
.accessibility-mode .event-card-time,
.accessibility-mode .breadcrumbs,
.accessibility-mode .breadcrumbs__separator {
    color: var(--upriu-a11y-text) !important;
    opacity: 0.85 !important;
}

.accessibility-mode .section-title,
.accessibility-mode .section-heading,
.accessibility-mode .page-title,
.accessibility-mode .widget-title,
.accessibility-mode .content-section-title,
.accessibility-mode .single-post-title,
.accessibility-mode .single-event-title {
    color: var(--upriu-a11y-heading) !important;
}

.accessibility-mode .footer-home-style .footer-nav a,
.accessibility-mode .footer-home-style .footer-contact-value,
.accessibility-mode .footer-home-style .footer-home-legal a,
.accessibility-mode .footer-home-style .copyright-home,
.accessibility-mode .footer-home-style .footer-contact-label {
    color: var(--upriu-a11y-link) !important;
}

.accessibility-mode .accessibility-panel {
    background: var(--upriu-a11y-panel-bg) !important;
    color: var(--upriu-a11y-text) !important;
    border-bottom-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode .accessibility-panel__settings {
    border-top-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode .accessibility-panel__chip[aria-pressed="true"],
.accessibility-mode .accessibility-panel__chip.is-active,
.accessibility-mode .accessibility-panel__link:hover,
.accessibility-mode .accessibility-panel__action:hover {
    background: var(--upriu-a11y-accent) !important;
    color: var(--upriu-a11y-bg) !important;
}

@media (max-width: 991px) {
    .accessibility-panel__toolbar {
        align-items: flex-start;
    }

    .accessibility-panel__toolbar-actions,
    .accessibility-panel__footer-actions {
        width: 100%;
        justify-content: flex-start;
    }

    .accessibility-panel__scheme {
        font-size: 16px;
    }
}

.feedback-layout {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 40px;
    margin-top: 28px;
}

.feedback-copy {
    font-size: 15px;
    line-height: 1.7;
    color: #223850;
}

.feedback-form {
    background: rgba(255, 255, 255, 0.68);
    padding: 28px;
}

.online-reception-widget {
    margin: 90px 0;
}

.sitemap-layout {
    margin-top: 24px;
}

.site-map {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 52px 80px;
    margin-top: 72px;
    padding-bottom: 120px;
}

.site-map-section {
    min-width: 0;
}

.site-map-title {
    margin: 0 0 24px;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: #0a3d62;
}

.site-map-list {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.site-map-list + .site-map-list {
    margin-top: 12px;
}

.site-map-list a {
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
    color: #2c3e50;
    text-decoration: none;
}

.site-map-list a:hover,
.site-map-list a:focus-visible {
    color: #2fb4be;
}

.site-map-empty {
    margin: 0;
    font-family: var(--font-secondary);
    font-size: 16px;
    line-height: 24px;
    letter-spacing: -0.02em;
    color: #8ba0b5;
}

@media (max-width: 1279px) {
    .msp-hero-layout {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .msp-registry-card {
        max-width: 640px;
    }

    .msp-support-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 991px) {
    .msp-copy .page-title,
    .msp-support-title {
        font-size: 32px;
    }

    .msp-copy .section-copy {
        font-size: 16px;
        line-height: 1.65;
    }

    .msp-registry-card {
        min-height: auto;
        padding: 28px 24px;
    }

    .msp-registry-link {
        font-size: 16px;
    }

    .msp-support-grid {
        grid-template-columns: 1fr;
    }

    .feedback-layout {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Single News Refinements
   ========================================================================== */

.breadcrumbs__separator {
    display: inline-block;
    margin: 0 8px;
    color: #a6b6c5;
}

.single-post-topline {
    display: grid;
    grid-template-columns: minmax(0, 862px) 302px;
    gap: 46px;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 26px;
}

.single-post-topline .single-post-header {
    margin-bottom: 0;
}

.single-post-sidebar-heading {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding-top: 8px;
}

.single-post-sidebar-heading .widget-title {
    margin: 0;
    color: #223850;
}

.single-post-layout {
    grid-template-columns: minmax(0, 862px) 302px;
    gap: 46px;
    justify-content: space-between;
    align-items: start;
}

.single-post-content {
    max-width: 862px;
}

.single-post-image {
    width: 100%;
    max-width: 862px;
    height: 640px;
    margin-bottom: 42px;
}

.single-post-image .post-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.single-post-sidebar {
    position: static;
    justify-self: end;
}

.single-post-sidebar .sidebar-widget {
    background: transparent;
    border-radius: 0;
    padding: 0;
}

body.single-news .single-post-sidebar-news-title {
    display: flex;
    margin: 0 0 28px;
    color: #223850;
    font-family: var(--font-primary);
    font-size: 18px;
    line-height: 28px;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.single-post-sidebar .other-news-list {
    display: flex;
    flex-direction: column;
    gap: 34px;
}

.single-post-sidebar .other-news-card.news-card {
    width: 302px;
    min-height: 464px;
    height: auto;
}

.single-post-sidebar .other-news-card .news-card-image,
.single-post-sidebar .other-news-card .news-card-image a {
    width: 302px;
    height: 224px;
}

.single-post-sidebar .other-news-card .news-card-body {
    min-height: 240px;
    padding: 24px 20px 28px;
}

.single-post-sidebar .other-news-card .news-card-title {
    font-size: 20px;
    line-height: 28px;
    font-weight: 600;
}

.single-post-sidebar .other-news-card .news-card-category {
    margin-top: auto;
}

.single-news-documents {
    margin-top: 62px;
}

.single-news-extra {
    margin-top: 62px;
}

.single-news-extra .content-section-title {
    margin-bottom: 24px;
    font-family: 'Montserrat', sans-serif;
    font-size: 22px;
    font-style: normal;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.single-news-extra-link {
    display: inline-block;
    max-width: 100%;
    margin-bottom: 24px;
    color: #2fb4be;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
    overflow-wrap: anywhere;
    text-decoration: underline;
}

.single-news-extra-link:hover {
    color: #0a3d62;
}

.single-news-extra-text {
    max-width: 862px;
    color: #2c3e50;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.single-news-extra-text p {
    margin: 0 0 8px;
}

.single-news-extra-text p:last-child {
    margin-bottom: 0;
}

.single-news-documents .content-section-title {
    margin-bottom: 30px;
}

.single-news-documents .doc-card-grid {
    gap: 34px;
}

@media (max-width: 1310px) {
    .single-post-topline,
    .single-post-layout {
        grid-template-columns: minmax(0, 1fr);
        justify-content: stretch;
    }

    .single-post-image {
        max-width: 100%;
        height: auto;
    }

    .single-post-image .post-image {
        height: auto;
    }

    .single-post-sidebar-heading {
        padding-top: 0;
    }

    .single-post-sidebar .other-news-list {
        flex-direction: row;
        flex-wrap: wrap;
    }
}

/* ==========================================================================
   Page Spacing And Single News Cards
   ========================================================================== */

.archive-list-section,
.single-post-section,
.page-content-section {
    padding-top: 0;
}

.breadcrumbs {
    padding: 40px 0 64px;
}

.single-post-sidebar-heading {
    padding-top: 0;
    min-height: 28px;
}

.single-post-sidebar .other-news-list {
    gap: 28px;
}

.single-post-sidebar .other-news-card.news-card {
    border-radius: 0;
    overflow: hidden;
    box-shadow: none;
}

.single-post-sidebar .other-news-card.news-card:hover {
    transform: none;
    box-shadow: none;
}

.single-post-content .partners-grid-compact {
    grid-template-columns: repeat(3, 264px);
    gap: 28px;
}

.single-post-content .partners-grid-compact .partner-card {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 264px;
    min-width: 264px;
    height: 128px;
    min-height: 128px;
    padding: 22px 24px;
    border-radius: 0;
}

.single-post-content .partners-grid-compact .partner-logo {
    position: static;
    left: auto;
    top: auto;
    transform: none;
    display: block;
    max-width: 100%;
    max-height: 72px;
    width: auto;
    height: auto;
    object-fit: contain;
    margin-bottom: 0;
}

.single-post-content .partners-grid-compact .partner-logo-placeholder {
    position: static;
    left: auto;
    top: auto;
    transform: none;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0;
}

@media (max-width: 1310px) {
    .single-post-content .partners-grid-compact {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .single-post-content .partners-grid-compact .partner-card {
        width: 100%;
        min-width: 0;
    }
}

/* ==========================================================================
   Single Event Page
   ========================================================================== */

.single-event-section {
    padding-bottom: 120px;
}

.single-event-layout {
    display: grid;
    grid-template-columns: minmax(0, 865px) 302px;
    justify-content: space-between;
    align-items: start;
    gap: 40px;
}

.single-event-content {
    width: 100%;
    max-width: 865px;
}

.single-event-header {
    margin-bottom: 36px;
}

.single-event-title {
    max-width: 850px;
    margin: 0 0 34px;
    color: #0A3D62;
    font-family: var(--font-primary);
    font-size: 44px;
    font-weight: 700;
    line-height: 54px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.single-event-tag,
.single-event-related-tag {
    color: #2FB4BE;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 22px;
    letter-spacing: -0.02em;
    text-transform: none;
}

.single-event-image {
    width: 865px;
    max-width: 100%;
    height: 640px;
    margin-bottom: 80px;
    overflow: hidden;
    background: #d4dce5;
}

.single-event-image .post-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.single-event-details {
    display: grid;
    grid-template-columns: 210px 210px;
    column-gap: 238px;
    row-gap: 50px;
    margin-bottom: 52px;
}

.single-event-detail-place {
    grid-column: 1 / -1;
}

.single-event-detail-label {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #A6B2C1;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.single-event-detail-label img {
    display: block;
    width: 28px;
    height: 28px;
    object-fit: contain;
    flex: 0 0 28px;
}

.single-event-detail strong {
    display: block;
    margin-top: 8px;
    color: #2C3E50;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.single-event-map {
    width: 862px;
    max-width: 100%;
    height: 342px;
    margin-bottom: 80px;
    overflow: hidden;
    background: #ffffff;
}

.single-event-map img,
.single-event-map iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
    object-fit: cover;
}

.single-event-block {
    margin-bottom: 72px;
}

.single-event-section-title {
    margin: 0 0 28px;
    color: #2C3E50;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.single-event-body {
    color: #2C3E50;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.single-event-body p {
    margin: 0 0 18px;
}

.single-event-official-link {
    color: #2FB4BE;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
    text-decoration: none;
}

.single-event-official-link:hover {
    color: #0A3D62;
}

.single-event-documents.doc-card-grid-2 {
    grid-template-columns: repeat(2, 414px);
    gap: 34px;
}

.single-event-content .partners-grid-compact {
    grid-template-columns: repeat(3, 264px);
    gap: 28px;
}

.single-event-content .partners-grid-compact .partner-card {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 264px;
    min-width: 264px;
    height: 128px;
    min-height: 128px;
    padding: 22px 24px;
    border-radius: 0;
}

.single-event-content .partners-grid-compact .partner-logo,
.single-event-content .partners-grid-compact .partner-logo-placeholder {
    position: static;
    left: auto;
    top: auto;
    transform: none;
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 72px;
    object-fit: contain;
    margin: 0;
}

.single-event-content .partners-grid-compact .partner-logo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
}

.single-event-register-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 860px;
    max-width: 100%;
    min-height: 68px;
    margin-top: 8px;
    border-radius: 60px;
    font-size: 18px;
    line-height: 32px;
    font-weight: 700;
    text-transform: none;
}

.single-event-sidebar {
    width: 302px;
    padding-top: 0;
    justify-self: end;
}

.single-event-sidebar-title {
    margin: 0 0 34px;
    color: #2C3E50;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.single-event-related-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.single-event-related-item {
    margin: 0;
    padding: 0 0 28px;
    border-bottom: 1px solid #D4DCE5;
}

.single-event-related-item + .single-event-related-item {
    padding-top: 28px;
}

.single-event-related-link {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-decoration: none;
}

.single-event-related-date {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    color: #A6B2C1;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 600;
    line-height: 28px;
    letter-spacing: -0.02em;
}

.single-event-related-date img {
    width: 24px;
    height: 24px;
    object-fit: contain;
    flex: 0 0 24px;
}

.single-event-related-title {
    margin-bottom: 14px;
    color: #2C3E50;
    font-family: var(--font-secondary);
    font-size: 20px;
    font-weight: 600;
    line-height: 27px;
    letter-spacing: -0.02em;
    text-transform: none;
}

.single-event-related-link:hover .single-event-related-title {
    color: #0A3D62;
}

@media (max-width: 1310px) {
    .single-event-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .single-event-sidebar {
        width: 100%;
    }

    .single-event-related-list {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 28px;
    }

    .single-event-related-item,
    .single-event-related-item + .single-event-related-item {
        padding-top: 0;
        padding-bottom: 24px;
    }
}

@media (max-width: 900px) {
    .single-event-title {
        font-size: 34px;
        line-height: 42px;
    }

    .single-event-image {
        height: auto;
    }

    .single-event-image .post-image {
        height: auto;
    }

    .single-event-details,
    .single-event-documents.doc-card-grid-2,
    .single-event-content .partners-grid-compact,
    .single-event-related-list {
        grid-template-columns: 1fr;
    }

    .single-event-content .partners-grid-compact .partner-card {
        width: 100%;
        min-width: 0;
    }
}

/* ==========================================================================
   Финальная доводка режима слабовидящих
   ========================================================================== */

.accessibility-mode,
.accessibility-mode *::before,
.accessibility-mode *::after {
    animation: none !important;
    transition: none !important;
}

.accessibility-mode .accessibility-panel {
    position: sticky;
    top: 0;
    z-index: 2000;
}

.accessibility-mode .accessibility-panel__inner {
    padding-top: 20px;
    padding-bottom: 28px;
}

.accessibility-mode .accessibility-panel__toolbar {
    align-items: flex-start;
    gap: 18px 28px;
}

.accessibility-mode .accessibility-panel__group,
.accessibility-mode .accessibility-panel__toolbar-actions,
.accessibility-mode .accessibility-panel__footer-actions,
.accessibility-mode .accessibility-panel__controls,
.accessibility-mode .accessibility-panel__setting-row {
    gap: 12px;
}

.accessibility-mode .accessibility-panel__chip,
.accessibility-mode .accessibility-panel__link,
.accessibility-mode .accessibility-panel__action {
    min-height: 46px;
    padding: 10px 16px;
    font-weight: 700;
}

.accessibility-mode .accessibility-panel__scheme {
    min-height: 54px;
}

.accessibility-mode .site-header,
.accessibility-mode .site-footer,
.accessibility-mode .fullscreen-menu,
.accessibility-mode .fullscreen-menu__inner,
.accessibility-mode .fullscreen-menu__top,
.accessibility-mode .fullscreen-menu__columns,
.accessibility-mode .fullscreen-menu__contacts,
.accessibility-mode .footer-main,
.accessibility-mode .footer-bottom,
.accessibility-mode .footer-home-style,
.accessibility-mode .newsletter-section,
.accessibility-mode .complaints-section,
.accessibility-mode .contacts-map-section,
.accessibility-mode .contact-modal__dialog,
.accessibility-mode .consumer-market-modal__dialog,
.accessibility-mode .msp-support-modal__dialog {
    background-image: none !important;
}

.accessibility-mode .fullscreen-menu,
.accessibility-mode .fullscreen-menu__inner,
.accessibility-mode .fullscreen-menu__top,
.accessibility-mode .fullscreen-menu__columns,
.accessibility-mode .fullscreen-menu__contacts {
    background: var(--upriu-a11y-bg) !important;
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode .fullscreen-menu__heading,
.accessibility-mode .fullscreen-menu__subnav a,
.accessibility-mode .fullscreen-menu__contact-label,
.accessibility-mode .fullscreen-menu__contact-value,
.accessibility-mode .fullscreen-menu__logo-subtitle,
.accessibility-mode .fullscreen-menu__logo-title {
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode .fullscreen-menu__top,
.accessibility-mode .fullscreen-menu__contacts {
    border-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode .fullscreen-menu__close {
    border: 2px solid var(--upriu-a11y-border) !important;
    background: transparent !important;
}

.accessibility-mode .fullscreen-menu__close span {
    background: var(--upriu-a11y-text) !important;
}

.accessibility-mode .hero-section,
.accessibility-mode .hero-slider,
.accessibility-mode .hero-slide,
.accessibility-mode .hero-content,
.accessibility-mode .hero-sidebar {
    min-height: auto !important;
}

.accessibility-mode .hero-slide,
.accessibility-mode .hero-content,
.accessibility-mode .hero-sidebar-card,
.accessibility-mode .news-card,
.accessibility-mode .partner-card,
.accessibility-mode .doc-link-card,
.accessibility-mode .info-card,
.accessibility-mode .event-card,
.accessibility-mode .archive-news-card,
.accessibility-mode .archive-events-list__item,
.accessibility-mode .cooperation-card,
.accessibility-mode .reporting-card,
.accessibility-mode .consumer-market-card,
.accessibility-mode .msp-support-card,
.accessibility-mode .single-post-sidebar .other-news-card.news-card {
    border-width: 2px !important;
    border-style: solid !important;
    border-radius: 0 !important;
}

.accessibility-mode .news-card-image,
.accessibility-mode .news-card-image a,
.accessibility-mode .single-post-featured,
.accessibility-mode .single-event-image,
.accessibility-mode .page-featured-image {
    border-radius: 0 !important;
}

.accessibility-mode .hero-slider-controls,
.accessibility-mode .hero-slider-arrows,
.accessibility-mode .hero-slider-dots,
.accessibility-mode .hero-slider-counter {
    color: var(--upriu-a11y-text) !important;
}

.accessibility-mode .hero-dot {
    border: 2px solid var(--upriu-a11y-border) !important;
    background: transparent !important;
}

.accessibility-mode .hero-dot.active {
    background: var(--upriu-a11y-accent) !important;
}

.accessibility-mode .btn,
.accessibility-mode button,
.accessibility-mode input,
.accessibility-mode textarea,
.accessibility-mode select,
.accessibility-mode .search-field,
.accessibility-mode .form-control,
.accessibility-mode .page-numbers,
.accessibility-mode .documents-tab,
.accessibility-mode .pill-tab,
.accessibility-mode .side-pill {
    border-radius: 0 !important;
}

.accessibility-mode input,
.accessibility-mode textarea,
.accessibility-mode select,
.accessibility-mode .search-field,
.accessibility-mode .form-control {
    font-weight: 700 !important;
    background: var(--upriu-a11y-bg) !important;
}

.accessibility-mode textarea {
    min-height: 180px !important;
}

.accessibility-mode .documents-table,
.accessibility-mode .documents-table-head,
.accessibility-mode .documents-table-row,
.accessibility-mode table,
.accessibility-mode th,
.accessibility-mode td {
    border-color: var(--upriu-a11y-border) !important;
}

.accessibility-mode .documents-table-head,
.accessibility-mode th {
    font-weight: 700 !important;
}

.accessibility-mode .documents-table-row,
.accessibility-mode .archive-events-list__item,
.accessibility-mode .archive-news-card {
    min-height: 72px;
}

.accessibility-mode .breadcrumbs,
.accessibility-mode .breadcrumbs a,
.accessibility-mode .news-card-date,
.accessibility-mode .event-card-date,
.accessibility-mode .event-card-time,
.accessibility-mode .single-event-meta-label,
.accessibility-mode .single-event-meta-value,
.accessibility-mode .footer-contact-label,
.accessibility-mode .logo-subtitle,
.accessibility-mode .newsletter-disclaimer,
.accessibility-mode .form-disclaimer {
    opacity: 1 !important;
}

.accessibility-mode .contact-modal__dialog,
.accessibility-mode .consumer-market-modal__dialog,
.accessibility-mode .msp-support-modal__dialog {
    max-height: none !important;
}

.accessibility-mode .contact-modal__backdrop,
.accessibility-mode .consumer-market-modal__backdrop,
.accessibility-mode .msp-support-modal__backdrop {
    backdrop-filter: none !important;
    opacity: 0.75 !important;
}

.accessibility-mode .contact-modal__close,
.accessibility-mode .consumer-market-modal__close,
.accessibility-mode .msp-support-modal__close {
    background: transparent !important;
}

.accessibility-mode[data-accessibility-images="off"] .header-contact-icon,
.accessibility-mode[data-accessibility-images="off"] .contact-ui-icon,
.accessibility-mode[data-accessibility-images="off"] .doc-icon img,
.accessibility-mode[data-accessibility-images="off"] .hero-sidebar-icon img,
.accessibility-mode[data-accessibility-images="off"] .cooperation-card-icon img,
.accessibility-mode[data-accessibility-images="off"] .reporting-card-icon img,
.accessibility-mode[data-accessibility-images="off"] .consumer-market-card-icon img,
.accessibility-mode[data-accessibility-images="off"] .msp-support-card-icon img,
.accessibility-mode[data-accessibility-images="off"] .single-event-meta img,
.accessibility-mode[data-accessibility-images="off"] .single-event-related-date img {
    display: block !important;
}

.accessibility-mode[data-accessibility-images="off"] .hero-slide::before,
.accessibility-mode[data-accessibility-images="off"] .hero-slide::after,
.accessibility-mode[data-accessibility-images="off"] .newsletter-section::before,
.accessibility-mode[data-accessibility-images="off"] .newsletter-section::after,
.accessibility-mode[data-accessibility-images="off"] .complaints-section::before,
.accessibility-mode[data-accessibility-images="off"] .complaints-section::after,
.accessibility-mode[data-accessibility-images="off"] .newsletter-bg::after,
.accessibility-mode[data-accessibility-images="off"] .info-card-art,
.accessibility-mode[data-accessibility-images="off"] .direction-card-art {
    content: none !important;
    display: none !important;
}

.accessibility-mode .site-logo img,
.accessibility-mode .fullscreen-menu__logo-icon img,
.accessibility-mode .footer-home-logo .logo-icon img {
    max-height: 88px;
    width: auto;
}

.accessibility-mode .partner-logo {
    max-height: 72px;
    width: auto;
    object-fit: contain;
}

.accessibility-mode .news-card-title,
.accessibility-mode .event-card-title,
.accessibility-mode .single-post-title,
.accessibility-mode .single-event-title,
.accessibility-mode .page-title,
.accessibility-mode .section-title,
.accessibility-mode .section-heading,
.accessibility-mode .widget-title {
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.accessibility-mode .news-card-category,
.accessibility-mode .event-card-tag,
.accessibility-mode .single-event-resource-link,
.accessibility-mode .documents-table a,
.accessibility-mode .consumer-market-modal__list a,
.accessibility-mode .msp-support-modal__content a,
.accessibility-mode .entry-content a,
.accessibility-mode .section-copy a {
    font-weight: 700 !important;
}

.accessibility-mode[data-accessibility-font-size="xlarge"] .fullscreen-menu__heading,
.accessibility-mode[data-accessibility-font-size="xlarge"] .main-navigation a,
.accessibility-mode[data-accessibility-font-size="xlarge"] .header-contact-item a,
.accessibility-mode[data-accessibility-font-size="xlarge"] .footer-nav a {
    font-size: 24px !important;
    line-height: 1.6 !important;
}

@media (max-width: 1310px) {
    .accessibility-mode .accessibility-panel__toolbar {
        justify-content: flex-start;
    }
}

@media (max-width: 900px) {
    .accessibility-mode .accessibility-panel__inner {
        padding-top: 14px;
        padding-bottom: 18px;
    }

    .accessibility-mode .accessibility-panel__label,
    .accessibility-mode .accessibility-panel__setting-label,
    .accessibility-mode .accessibility-panel__chip,
    .accessibility-mode .accessibility-panel__link,
    .accessibility-mode .accessibility-panel__action,
    .accessibility-mode .accessibility-panel__scheme {
        font-size: 16px !important;
    }

    .accessibility-mode .accessibility-panel__heading {
        font-size: 22px !important;
    }

    .accessibility-mode .fullscreen-menu__columns,
    .accessibility-mode .fullscreen-menu__contacts {
        gap: 20px !important;
    }

    .accessibility-mode .hero-slider-controls {
        gap: 12px !important;
    }
}

/* ==========================================================================
   Главная страница: мобильная версия по макету Figma
   ========================================================================== */

@media (max-width: 576px) {
    :root {
        --container-padding: 30px;
    }

    body.home {
        min-width: 320px;
        background: #f1f5f9;
        overflow-x: hidden;
    }

    body.home .site-main {
        width: 100%;
        max-width: 100vw;
        overflow-x: hidden;
    }

    body.home .site-header {
        position: relative;
        background: #f1f5f9;
    }

    body.home .header-top {
        height: 130px;
        padding: 30px 0;
        background: #f1f5f9;
    }

    body.home .header-top-inner {
        position: relative;
        align-items: center;
        justify-content: space-between;
        gap: 0;
        height: 70px;
    }

    body.home .header-logo {
        min-width: 0;
        flex: 0 0 auto;
    }

    body.home .site-logo.site-logo-with-text {
        gap: 13px;
        width: 194px;
        height: 70px;
    }

    body.home .site-logo.site-logo-with-text .logo-full {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    body.home .site-logo.site-logo-with-text .logo-full img {
        width: 50px;
        height: 70px;
    }

    body.home .site-logo.site-logo-with-text .logo-text {
        gap: 6px;
        max-width: 130px;
    }

    body.home .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
    }

    body.home .logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
    }

    body.home .header-main {
        width: auto;
        min-width: 82px;
        flex: 0 0 82px;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        gap: 30px;
    }

    body.home .header-utility {
        display: flex;
        width: auto;
        flex: 0 0 28px;
        gap: 0;
        order: 0;
    }

    body.home .header-utility .header-contacts {
        display: none;
    }

    body.home .header-search {
        display: block;
        width: 28px;
        max-width: 28px;
        flex: 0 0 28px;
    }

    body.home .search-form {
        min-height: 28px;
        padding: 0;
        background: transparent;
    }

    body.home .search-field {
        position: absolute;
        width: 1px;
        height: 1px;
        opacity: 0;
        pointer-events: none;
    }

    body.home .search-submit,
    body.home .search-submit svg {
        width: 28px;
        height: 28px;
    }

    body.home .header-nav-row {
        width: 24px;
        flex: 0 0 24px;
        justify-content: flex-end;
        order: 1;
    }

    body.home .mobile-menu-toggle {
        display: flex;
        width: 24px;
        height: 20px;
    }

    body.home .mobile-menu-toggle span:nth-child(2) {
        align-self: flex-end;
        width: 12px;
    }

    body.home .main-navigation {
        position: absolute;
        top: 100px;
        left: 30px;
        right: 30px;
        z-index: 50;
        width: auto;
        border-radius: 0;
    }

    body.home .hero-section {
        height: auto;
        padding-bottom: 0;
        overflow: hidden;
        background: #f1f5f9;
    }

    body.home .hero-slider {
        width: 100%;
        max-width: 100vw;
        min-height: 420px;
        height: 420px;
        overflow: hidden;
        background: #2c3e50;
    }

    body.home .hero-slide,
    body.home .hero-slide.active,
    body.home .hero-slide-bg,
    body.home .hero-bg-placeholder,
    body.home .hero-overlay {
        width: 100%;
        min-height: 420px;
        height: 420px;
    }

    body.home .hero-slide-bg {
        left: 50%;
        transform: translateX(-50%);
        width: 630px;
        max-width: none;
        overflow: hidden;
    }

    body.home .hero-bg-image {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    body.home .hero-overlay {
        background: transparent;
    }

    body.home .hero-bg-placeholder {
        background: #0A3D62;
    }

    body.home .hero-content {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 420px;
        padding: 0;
        align-items: stretch;
    }

    body.home .hero-title {
        left: 20px;
        right: auto;
        top: 232px;
        bottom: auto;
        width: min(420px, 87.5vw);
        max-width: calc(100vw - min(60px, 12.5vw));
        color: #fff;
        font-size: min(28px, 5.833vw);
        line-height: min(34px, 7.083vw);
        letter-spacing: -0.02em;
    }

    body.home .hero-content .btn {
        left: 20px;
        top: 330px;
        bottom: auto;
        width: min(226px, 47.083vw);
        min-width: 150px;
        min-height: 60px;
        height: 60px;
        padding: 0 24px;
        font-size: 16px;
        line-height: 32px;
        font-weight: 700;
        white-space: nowrap;
    }

    body.home .hero-slider-controls {
        left: auto;
        right: 30px;
        top: 330px;
        bottom: auto;
        display: grid;
        grid-template-columns: 24px 128px;
        align-items: center;
        gap: 10px;
        width: 162px;
        height: 60px;
        padding: 0;
    }

    body.home .hero-slider-counter {
        order: 0;
        width: 24px;
        min-width: 24px;
        color: #fff;
        font-size: 16px;
        line-height: 24px;
        text-align: center;
    }

    body.home .hero-slider-arrows {
        order: 1;
        display: flex;
        gap: 10px;
    }

    body.home .hero-arrow {
        width: 60px;
        height: 60px;
        flex: 0 0 60px;
        padding: 0;
    }

    body.home .hero-arrow svg {
        width: 12px;
        height: 19px;
    }

    @media (max-width: 430px) {
        body.home .hero-slider-controls {
            right: 20px;
            grid-template-columns: 24px 130px;
            gap: 10px;
            width: 164px;
        }

        body.home .hero-slider-arrows {
            gap: 10px;
        }
    }

    @media (max-width: 350px) {
        body.home .hero-slider-controls {
            left: calc(100vw - 164px);
            right: auto;
            grid-template-columns: 24px 130px;
            gap: 10px;
            width: 164px;
        }

        body.home .hero-slider-counter {
            width: 24px;
            min-width: 24px;
        }

        body.home .hero-slider-arrows {
            gap: 10px;
        }

        body.home .hero-arrow {
            width: 60px;
            height: 60px;
            flex-basis: 60px;
        }
    }

    body.home .hero-sidebar {
        position: static;
        display: flex;
        width: 100%;
        max-width: 100vw;
        height: auto;
        padding: 8px 8px 0;
        gap: 8px;
        background: #f1f5f9;
        overflow: hidden;
    }

    body.home .hero-sidebar-card {
        width: 100%;
        max-width: 100%;
        height: 112px;
        padding: 0 32px;
        gap: 40px;
        background: #fff;
    }

    body.home .hero-sidebar-icon,
    body.home .hero-sidebar-icon img,
    body.home .hero-sidebar-icon svg {
        width: 52px;
        height: 52px;
        flex-basis: 52px;
    }

    body.home .hero-sidebar-card:nth-child(3) .hero-sidebar-icon,
    body.home .hero-sidebar-card:nth-child(3) .hero-sidebar-icon img {
        width: 68px;
        height: 68px;
        flex-basis: 68px;
        margin-left: -8px;
        margin-right: -8px;
    }

    body.home .hero-sidebar-title {
        max-width: calc(100% - 84px);
        font-size: 16px;
        line-height: 28px;
        letter-spacing: -0.02em;
    }

    body.home .news-section,
    body.home .directions-section,
    body.home .contact-form-section,
    body.home .partners-section {
        padding: 72px 0 0;
        background: #f1f5f9;
    }

    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid {
        max-width: 100%;
        padding: 0 30px;
    }

    body.home .section-header {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 28px;
        margin-bottom: 30px;
    }

    body.home .section-title,
    body.home .contact-form-title,
    body.home .newsletter-title,
    body.home .gosuslugi-title,
    body.home .home-contacts-card .content-section-title {
        font-size: 22px;
        line-height: 28px;
        letter-spacing: -0.02em;
    }

    body.home .section-link {
        order: 3;
        margin-top: 22px;
        font-size: 16px;
        line-height: 20px;
        gap: 12px;
    }

    body.home .news-section .section-header {
        margin-bottom: 30px;
    }

    body.home .news-section .news-grid {
        display: flex;
        grid-template-columns: none;
        gap: 16px;
        width: calc(100vw - 30px);
        margin-right: -30px;
        overflow-x: auto;
        scrollbar-width: none;
        scroll-snap-type: x proximity;
    }

    body.home .news-section .news-grid::-webkit-scrollbar {
        display: none;
    }

    body.home .news-section .news-card {
        width: 252px;
        min-width: 252px;
        height: 392px;
        min-height: 392px;
        max-height: 392px;
        scroll-snap-align: start;
    }

    body.home .news-section .news-card-image,
    body.home .news-section .news-card-image a,
    body.home .news-section .news-image,
    body.home .news-section .news-image-placeholder {
        width: 252px;
        height: 186px;
    }

    body.home .news-section .news-card-body {
        height: 206px;
        padding: 24px;
    }

    body.home .news-card-date {
        margin-bottom: 16px;
        font-size: 14px;
        line-height: 19px;
        gap: 8px;
    }

    body.home .news-card-date svg {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    body.home .news-card-title {
        min-height: 72px;
        font-size: 16px;
        line-height: 24px;
    }

    body.home .news-card-category {
        font-size: 14px;
        line-height: 22px;
    }

    body.home .newsletter-section {
        position: relative;
        height: 520px;
        min-height: 520px;
        margin-top: 72px;
        padding: 0;
        overflow: hidden;
        background: #0a3d62;
    }

    body.home .newsletter-section > .container-fluid {
        padding: 0 30px;
    }

    body.home .newsletter-section::before {
        left: -171px;
        top: 349px;
        bottom: auto;
        width: 342px;
        height: 342px;
        border-radius: 50%;
        background: #2fb4be;
        filter: blur(133.333px);
        opacity: 1;
    }

    body.home .newsletter-bg {
        display: block;
        z-index: 1;
    }

    body.home .newsletter-bg::after {
        right: auto;
        bottom: auto;
        left: calc(50% + 46px);
        top: 128px;
        width: 380px;
        height: 520px;
        background: url("../images/logohomepodpiskabanner.png") left top / contain no-repeat;
        mix-blend-mode: normal;
        opacity: 1;
    }

    body.home .newsletter-section .newsletter-overlay {
        display: none;
    }

    body.home .newsletter-content {
        position: static;
        display: block;
        z-index: auto;
    }

    body.home .newsletter-info {
        display: contents;
    }

    body.home .newsletter-title {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 80px;
        width: calc(100% - 60px);
        max-width: 422px;
        min-height: 84px;
        margin: 0;
        color: #fff;
    }

    body.home .newsletter-description {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 194px;
        width: calc(100% - 60px);
        max-width: 347px;
        margin: 0;
        font-size: 16px;
        line-height: 28px;
        color: #fff;
    }

    body.home .newsletter-form-container {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 254px;
        width: calc(100% - 60px);
        max-width: none;
    }

    body.home .newsletter-form {
        gap: 0;
		margin-top: 80px;
    }

    body.home .newsletter-form .form-group {
        margin-bottom: 0;
    }

    body.home .form-control {
        min-height: 60px;
        padding: 18px 30px;
        font-size: 16px;
        line-height: 24px;
        border-radius: 60px;
    }

    body.home .newsletter-form .form-control {
        min-height: 60px;
        height: 60px;
        padding: 14px 32px;
        font-size: 16px;
        line-height: 32px;
        background: #f1f5f9;
    }

    body.home .newsletter-form .btn,
    body.home .contact-form .btn,
    body.home .gosuslugi-section .btn,
    body.home .home-contacts-card .btn {
        width: 100%;
        min-width: 0;
        min-height: 60px;
        padding: 18px 30px;
        font-size: 16px;
        line-height: 24px;
    }

    body.home .newsletter-form .btn {
        height: 60px;
        min-height: 60px;
        margin-top: 12px;
        padding: 14px 40px;
        line-height: 32px;
        font-weight: 700;
    }

    body.home .newsletter-form .newsletter-disclaimer,
    body.home .form-disclaimer {
        width: 100%;
        max-width: 100%;
        margin-top: 16px;
        padding: 0 20px;
        color: #A6B2C1;
        font-size: 12px;
        line-height: 19px;
        text-align: center;
    }

    body.home .directions-section {
        padding-top: 72px;
    }

    body.home .directions-section .section-link {
        margin-top: 0;
    }

    body.home .home-directions-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 20px;
    }

    body.home .info-card {
        width: 100%;
        height: 302px;
        min-height: 302px;
        padding: 30px;
    }

    body.home .info-card-number {
        left: 30px;
        top: 30px;
        width: 60px;
        height: 60px;
        font-size: 18px;
        line-height: 28px;
    }

    body.home .info-card h3 {
        left: 30px;
        top: 126px;
        max-width: 265px;
        font-size: 18px;
        line-height: 24px;
    }

    body.home .info-card a {
        left: 30px;
        top: auto;
        bottom: 30px;
        font-size: 16px;
        line-height: 20px;
    }

    body.home .info-card-art {
        top: 51px;
        right: -59px;
        width: 200px;
        height: 200px;
    }

    body.home .contact-form-section {
        padding-top: 80px;
        min-height: 0;
        background: rgba(13, 70, 114, 0.04);
    }

    body.home .contact-form-wrapper {
        display: flex;
        flex-direction: column;
        gap: 28px;
    }

    body.home .contact-form-title {
        max-width: 220px;
        margin-bottom: 16px;
    }

    body.home .contact-form-description {
        max-width: 390px;
        margin-bottom: 30px;
        font-size: 12px;
        line-height: 16px;
    }

    body.home .contact-form-image {
        order: 3;
        display: flex;
        justify-content: center;
        margin-top: 28px;
    }

    body.home .contact-form-image img {
        width: 330px;
        transform: rotate(-12deg);
    }

    body.home .contact-form-container {
        width: 100%;
        max-width: none;
    }

    body.home .contact-form .form-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 12px;
    }

    body.home .contact-form .form-group {
        margin-bottom: 12px;
    }

    body.home textarea.form-control {
        min-height: 222px;
        border-radius: 24px;
    }

    body.home .form-actions {
        gap: 12px;
        margin-top: 0;
    }

    body.home .partners-section {
        padding-top: 72px;
    }

    body.home .partners-tabs {
        display: flex;
        width: calc(100vw - 60px);
        gap: 18px;
        overflow-x: auto;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
    }

    body.home .partners-tabs::-webkit-scrollbar {
        display: none;
    }

    body.home .partner-tab {
        flex: 0 0 auto;
        font-size: 12px;
        line-height: 16px;
        white-space: nowrap;
    }

    body.home .partners-section .partners-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }

    body.home .partners-section .partner-card {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
        width: 100%;
        height: 128px;
        min-height: 128px;
        gap: 10px;
        padding: 28px 14px 18px;
    }

    body.home .partners-section .partner-card.is-hidden {
        display: none;
    }

    body.home .partners-section .partner-logo,
    body.home .partners-section .partner-logo-placeholder {
        display: block;
        align-self: center;
        width: 42px;
        height: 30px;
        max-width: 72px;
        max-height: 38px;
        flex: 0 0 auto;
        margin: 0;
        object-fit: contain;
    }

    body.home .partners-section .partner-name {
        display: -webkit-box;
        align-self: center;
        max-width: none;
        width: 100%;
        min-width: 0;
        overflow: hidden;
        font-size: 9px;
        line-height: 12px;
        text-align: center;
        text-wrap: balance;
        overflow-wrap: normal;
        -webkit-line-clamp: 4;
        -webkit-box-orient: vertical;
        text-overflow: ellipsis;
    }

    body.home .gosuslugi-section {
        min-height: 544px;
        margin-top: 72px;
        padding: 48px 0 0;
        background: #0a3d62;
    }

    body.home .gosuslugi-section::before {
        left: -171px;
        bottom: -176px;
        width: 342px;
        height: 342px;
        background: #2FB4BE;
        filter: blur(133px);
        opacity: 0.9;
    }

    body.home .gosuslugi-section > .container-fluid {
        padding: 0 30px;
    }

    body.home .gosuslugi-content {
        display: block;
        min-height: 483px;
    }

    body.home .gosuslugi-title {
        max-width: 420px;
        margin-bottom: 30px;
        color: #fff;
    }

    body.home .gosuslugi-description {
        margin-bottom: 24px;
        font-size: 14px;
        line-height: 19px;
        color: #fff;
    }

    body.home .gosuslugi-image {
        position: absolute;
        left: 33%;
        right: auto;
        bottom: -96px;
        z-index: 1;
        width: 420px;
        max-width: none;
        height: 300px;
        transform: translateX(-42%);
        overflow: hidden;
    }

    body.home .gosuslugi-image img {
        display: block;
        width: 420px;
        max-width: none;
        height: 300px;
        object-fit: cover;
        object-position: center center;
    }

    body.home .partner-strip-section {
        padding: 72px 0 72px;
        background: #fff;
    }

    body.home .partner-strip-section .section-header {
        align-items: center;
        margin-bottom: 36px;
    }

    body.home .partner-strip-viewport {
        overflow: hidden;
    }

    body.home .partner-strip-list {
        display: flex;
        flex-wrap: nowrap;
        justify-content: flex-start;
        gap: 36px;
    }

    body.home .partner-strip-item {
        flex: 0 0 calc(50% - 18px);
        min-height: 80px;
    }

    body.home .partner-strip-logo {
        max-height: 58px;
    }

    body.home .partner-strip-controls {
        margin-top: 24px;
        gap: 8px;
    }

    body.home .partner-strip-controls .hero-arrow {
        width: 60px;
        height: 60px;
    }

    body.home .home-contacts-section {
        background: #fff;
    }

    body.home .home-contacts-map {
        min-height: 700px;
        padding: 30px 0;
    }

    body.home .home-contacts-map-embed iframe {
        height: 700px;
    }

    body.home .home-contacts-card {
        width: 100%;
        max-width: none;
        height: auto;
        min-height: 312px;
        padding: 30px;
        background: #fff;
        box-shadow: none;
    }

    body.home .home-contacts-card .content-section-title {
        margin-bottom: 30px;
    }

    body.home .home-contacts-list {
        gap: 16px;
        margin-bottom: 30px;
        font-size: 20px;
        line-height: 27px;
    }

    body.home .home-contacts-item {
        gap: 8px;
    }

    body.home .home-contacts-icon,
    body.home .home-contacts-icon img {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    body.home .footer-home-style {
        background: #f1f5f9;
    }

    body.home .footer-home-style .footer-main {
        padding: 80px 0 72px;
    }

    body.home .footer-home-style .footer-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 66px 32px;
        min-height: 0;
        align-items: start;
    }

    body.home .footer-home-style .footer-app {
        order: 0;
        grid-column: 1 / -1;
        min-height: 0;
        justify-content: center;
    }

    body.home .footer-app .app-screenshot {
        width: 100%;
        max-width: 420px;
        height: auto;
        min-height: 0;
        border-radius: 0;
        background: transparent;
    }

    body.home .footer-app .app-screenshot img {
        width: 100%;
        height: auto;
        object-fit: contain;
    }

    body.home .footer-gosuslugi-widget iframe {
        width: 229px;
        height: 450px;
        margin: 0 auto;
    }

    body.home .footer-home-style .footer-about {
        order: 1;
        grid-column: 1 / -1;
        min-height: 0;
        display: contents;
    }

    body.home .footer-home-style .footer-logo {
        order: 1;
        grid-column: 1 / -1;
    }

    body.home .footer-home-style .footer-home-logo {
        width: 194px;
        gap: 13px;
    }

    body.home .footer-home-style .footer-home-logo .logo-icon {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    body.home .footer-home-style .footer-home-logo .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
        color: #2c3e50;
    }

    body.home .footer-home-style .footer-home-logo .logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
        color: #0a3d62;
    }

    body.home .footer-home-style .footer-nav {
        order: 2;
        grid-column: 1;
        min-height: 0;
    }

    body.home .footer-home-style .footer-nav ul {
        min-height: 382px;
        gap: 0;
    }

    body.home .footer-home-style .footer-nav a {
        font-size: 16px;
        line-height: 22px;
    }

    body.home .footer-home-style .footer-contacts {
        order: 3;
        grid-column: 2;
        min-height: 0;
        gap: 36px;
        justify-content: flex-start;
    }

    body.home .footer-home-style .footer-contact-item {
        grid-template-columns: 24px minmax(0, 1fr);
        column-gap: 8px;
        row-gap: 8px;
    }

    body.home .footer-home-style .footer-contact-item .contact-ui-icon {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    body.home .footer-home-style .footer-contact-label {
        font-size: 14px;
        line-height: 19px;
    }

    body.home .footer-home-style .footer-contact-value,
    body.home .footer-home-style .footer-contact-value:hover {
        font-size: 18px;
        line-height: 25px;
    }

    body.home .footer-home-style .footer-home-legal {
        order: 4;
        grid-column: 1 / -1;
        max-width: 243px;
    }

    body.home .footer-home-style .copyright-home,
    body.home .footer-home-style .footer-home-legal a {
        font-size: 16px;
        line-height: 22px;
    }
}

@media (max-width: 380px) {
    body.home .hero-sidebar-title {
        font-size: 14px;
        line-height: 22px;
    }

    body.home .footer-home-style .footer-grid {
        grid-template-columns: 1fr;
    }

    body.home .footer-home-style .footer-nav,
    body.home .footer-home-style .footer-contacts {
        grid-column: 1;
        grid-row: auto;
    }

    body.home .footer-home-style .footer-about {
        display: contents;
    }
}

/* Mobile gutter standard: keep page content 20px from viewport edges. */
@media (max-width: 576px) {
    :root {
        --adaptive-container-gutter: 40px;
        --container-padding: 20px;
    }

    .container,
    .container-fluid,
    body.post-type-archive-news .container-fluid,
    body.single-news .container-fluid,
    .header-top > .container-fluid,
    .fullscreen-menu__inner {
        width: calc(100% - 40px);
        max-width: none;
        padding-right: 0;
        padding-left: 0;
    }

    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid,
    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid,
    body.post-type-archive-news .newsletter-section > .container-fluid,
    body.single-news .newsletter-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    body.home .newsletter-title,
    body.home .newsletter-description,
    body.home .newsletter-form-container,
    body.post-type-archive-news .newsletter-title,
    body.post-type-archive-news .newsletter-description,
    body.post-type-archive-news .newsletter-form-container,
    body.single-news .newsletter-title,
    body.single-news .newsletter-description,
    body.single-news .newsletter-form-container {
        left: 30px;
        width: calc(100% - 60px);
    }

    body.home .news-section .news-grid,
    body.single-news .single-post-sidebar .other-news-list {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        width: calc(100vw - 20px);
        margin-right: -20px;
    }
}

@media (max-width: 576px) {
    body.post-type-archive-event,
    body.single-event,
    body.post-type-archive-event .site-main,
    body.single-event .site-main {
        background: #f1f5f9;
    }

    body.post-type-archive-event .container-fluid,
    body.single-event .container-fluid {
        width: calc(100% - 40px);
        max-width: none;
        padding-right: 0;
        padding-left: 0;
    }

    body.post-type-archive-event .breadcrumbs,
    body.single-event .breadcrumbs {
        padding: 26px 0 34px;
        color: #a6b2c1;
        font-size: 12px;
        line-height: 16px;
    }

    body.post-type-archive-event .breadcrumbs a,
    body.single-event .breadcrumbs a {
        color: #a6b2c1;
    }

    body.post-type-archive-event .events-archive-section,
    body.single-event .single-event-section {
        padding: 0 0 72px;
        background: #f1f5f9;
    }

    body.post-type-archive-event .events-archive-mobile-header {
        display: block;
    }

    body.post-type-archive-event .events-archive-content .events-archive-header {
        display: none;
    }

    body.post-type-archive-event .archive-list-title {
        margin: 0 0 30px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.post-type-archive-event .events-archive-layout {
        display: flex;
        flex-direction: column;
        gap: 34px;
    }

    body.post-type-archive-event .events-archive-sidebar,
    body.post-type-archive-event .events-archive-content {
        width: 100%;
    }

    body.post-type-archive-event .events-filter-card {
        gap: 14px;
    }

    body.post-type-archive-event .events-filter-card .event-search-group {
        margin-bottom: 0;
    }

    body.post-type-archive-event .events-filter-card .form-control,
    body.post-type-archive-event .event-select-button {
        min-height: 60px;
        padding: 18px 56px 18px 30px;
        border: 0;
        border-radius: 60px;
        background-color: #fff;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        line-height: 24px;
        letter-spacing: -0.02em;
        box-shadow: none;
    }

    body.post-type-archive-event .event-select-button {
        padding-right: 30px;
    }

    body.post-type-archive-event .event-select-button::after {
        width: 8px;
        height: 14px;
    }

    body.post-type-archive-event .event-search-group::after {
        right: 30px;
        width: 28px;
        height: 28px;
    }

    body.post-type-archive-event .filter-checkbox {
        gap: 8px;
        color: #6d8091;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        line-height: 19px;
    }

    body.post-type-archive-event .filter-checkbox input {
        width: 20px;
        height: 20px;
        flex: 0 0 20px;
    }

    body.post-type-archive-event .archive-side-button {
        min-height: 60px;
        margin-top: 16px;
        padding: 18px 30px;
        border-radius: 60px;
        font-size: 16px;
        line-height: 24px;
        font-weight: 700;
    }

    body.post-type-archive-event .event-list-item {
        display: flex;
        flex-direction: column;
        gap: 0;
        padding: 34px 0;
        border-bottom: 1px solid rgba(13, 70, 114, 0.12);
    }

    body.post-type-archive-event .event-list-date {
        gap: 8px;
        margin-bottom: 22px;
        color: #a6b2c1;
        font-size: 14px;
        line-height: 19px;
        font-weight: 600;
    }

    body.post-type-archive-event .event-list-meta-item {
        gap: 8px;
    }

    body.post-type-archive-event .event-list-meta-icon {
        width: 20px;
        height: 20px;
        flex: 0 0 20px;
    }

    body.post-type-archive-event .event-list-title {
        margin: 0 0 14px;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 18px;
        font-weight: 700;
        line-height: 24px;
        letter-spacing: -0.02em;
    }

    body.post-type-archive-event .event-list-tag {
        margin-bottom: 18px;
        color: #2fb4be;
        font-size: 14px;
        line-height: 22px;
        font-weight: 600;
    }

    body.post-type-archive-event .event-list-excerpt {
        max-width: none;
        margin-bottom: 26px;
        color: #a6b2c1;
        font-size: 14px;
        line-height: 22px;
    }

    body.post-type-archive-event .event-list-actions {
        width: 100%;
        gap: 18px;
        align-items: stretch;
        justify-self: stretch;
    }

    body.post-type-archive-event .event-status {
        width: 100%;
        color: #27ae60;
        font-size: 14px;
        line-height: 18px;
    }

    body.post-type-archive-event .event-list-actions .btn {
        width: 100%;
        min-width: 0;
        min-height: 60px;
        padding: 18px 30px;
        border-radius: 60px;
        font-size: 14px;
        line-height: 24px;
    }

    body.post-type-archive-event .pagination {
        margin-top: 34px;
    }

    body.single-event .single-event-layout {
        display: block;
    }

    body.single-event .single-event-content {
        max-width: 100%;
    }

    body.single-event .single-event-header {
        margin-bottom: 24px;
    }

    body.single-event .single-event-title {
        max-width: 100%;
        margin: 0 0 18px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.single-event .single-event-tag,
    body.single-event .single-event-related-tag {
        color: #2fb4be;
        font-size: 14px;
        line-height: 22px;
        font-weight: 600;
    }

    body.single-event .single-event-image {
        width: 100%;
        height: 300px;
        max-width: 100%;
        min-height: 0;
        margin-bottom: 28px;
    }

    body.single-event .single-event-image .post-image {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    body.single-event .single-event-details {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 24px 34px;
        margin-bottom: 28px;
    }

    body.single-event .single-event-detail-place {
        grid-column: 1 / -1;
    }

    body.single-event .single-event-detail-label {
        gap: 8px;
        color: #a6b2c1;
        font-size: 14px;
        line-height: 19px;
    }

    body.single-event .single-event-detail-label img {
        width: 20px;
        height: 20px;
        flex: 0 0 20px;
    }

    body.single-event .single-event-detail strong {
        margin-top: 6px;
        color: #2c3e50;
        font-size: 14px;
        line-height: 19px;
    }

    body.single-event .single-event-map {
        width: 100%;
        height: 300px;
        min-height: 0;
        margin-bottom: 54px;
    }

    body.single-event .single-event-block {
        margin-bottom: 54px;
    }

    body.single-event .single-event-section-title,
    body.single-event .single-event-sidebar-title {
        margin: 0 0 24px;
        color: #2c3e50;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 700;
        line-height: 23px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.single-event .single-event-body {
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        line-height: 22px;
        letter-spacing: -0.02em;
    }

    body.single-event .single-event-body p {
        margin-bottom: 18px;
    }

    body.single-event .single-event-official-link {
        display: inline-block;
        max-width: 100%;
        color: #2fb4be;
        font-size: 14px;
        line-height: 22px;
        overflow-wrap: anywhere;
        text-decoration: underline;
    }

    body.single-event .single-event-documents.doc-card-grid-2 {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }

    body.single-event .single-event-documents .doc-link-card {
        width: 100%;
        min-width: 0;
        height: 80px;
        min-height: 80px;
        padding: 18px 14px;
        gap: 10px;
    }

    body.single-event .single-event-documents .doc-icon,
    body.single-event .single-event-documents .doc-icon img {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }

    body.single-event .single-event-documents .doc-link-card span:last-child {
        font-size: 10px;
        line-height: 14px;
        font-weight: 700;
    }

    body.single-event .single-event-content .partners-grid-compact {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }

    body.single-event .single-event-content .partners-grid-compact .partner-card {
        width: 100%;
        min-width: 0;
        height: 80px;
        min-height: 80px;
        padding: 16px 18px;
    }

    body.single-event .single-event-content .partners-grid-compact .partner-logo,
    body.single-event .single-event-content .partners-grid-compact .partner-logo-placeholder {
        max-height: 42px;
    }

    body.single-event .single-event-register-btn {
        width: 100%;
        min-height: 60px;
        margin: 0 0 54px;
        padding: 18px 30px;
        border-radius: 60px;
        font-size: 14px;
        line-height: 24px;
    }

    body.single-event .single-event-sidebar {
        width: 100%;
        margin-top: 0;
    }

    body.single-event .single-event-related-list {
        display: flex;
        flex-direction: column;
        gap: 0;
    }

    body.single-event .single-event-related-item,
    body.single-event .single-event-related-item + .single-event-related-item {
        padding: 0 0 24px;
        margin: 0 0 24px;
        border-bottom: 1px solid #d4dce5;
    }

    body.single-event .single-event-related-date {
        margin-bottom: 14px;
        color: #a6b2c1;
        font-size: 14px;
        line-height: 19px;
    }

    body.single-event .single-event-related-date img {
        width: 20px;
        height: 20px;
        flex: 0 0 20px;
    }

    body.single-event .single-event-related-title {
        margin-bottom: 12px;
        font-size: 16px;
        line-height: 24px;
        font-weight: 700;
    }

    body.post-type-archive-event .newsletter-section,
    body.single-event .newsletter-section {
        position: relative;
        height: 520px;
        min-height: 520px;
        padding: 0;
        overflow: hidden;
        background: #0a3d62;
    }

    body.post-type-archive-event .newsletter-section > .container-fluid,
    body.single-event .newsletter-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    body.post-type-archive-event .newsletter-bg,
    body.single-event .newsletter-bg {
        display: block;
        z-index: 1;
    }

    body.post-type-archive-event .newsletter-bg::after,
    body.single-event .newsletter-bg::after {
        right: auto;
        bottom: auto;
        left: calc(50% + 46px);
        top: 128px;
        width: 380px;
        height: 520px;
        background: url("../images/logohomepodpiskabanner.png") left top / contain no-repeat;
        mix-blend-mode: normal;
        opacity: 1;
    }

    body.post-type-archive-event .newsletter-overlay,
    body.single-event .newsletter-overlay {
        display: none;
    }

    body.post-type-archive-event .newsletter-content,
    body.single-event .newsletter-content {
        position: relative;
        z-index: 2;
        min-height: 520px;
        padding: 74px 0 50px;
    }

    body.post-type-archive-event .newsletter-title,
    body.single-event .newsletter-title {
        max-width: 100%;
        margin: 0;
        color: #fff;
        font-size: 22px;
        line-height: 28px;
        letter-spacing: -0.02em;
    }

    body.post-type-archive-event .newsletter-description,
    body.single-event .newsletter-description {
        max-width: 100%;
        margin: 30px 0 28px;
        color: #fff;
        font-size: 16px;
        line-height: 28px;
    }

    body.post-type-archive-event .newsletter-form-container,
    body.single-event .newsletter-form-container {
        max-width: 100%;
    }

    body.post-type-archive-event .newsletter-form,
    body.single-event .newsletter-form {
        display: flex;
        flex-direction: column;
    }

    body.post-type-archive-event .newsletter-form .form-control,
    body.single-event .newsletter-form .form-control {
        width: 100%;
        height: 60px;
        min-height: 60px;
        padding: 14px 32px;
        border-radius: 60px;
        background: #f1f5f9;
        font-size: 16px;
        line-height: 32px;
    }

    body.post-type-archive-event .newsletter-form .btn,
    body.single-event .newsletter-form .btn {
        width: 100%;
        min-height: 60px;
        margin-top: 12px;
        padding: 14px 40px;
        border-radius: 60px;
        font-size: 16px;
        line-height: 32px;
    }

    body.post-type-archive-event .newsletter-form .newsletter-disclaimer,
    body.single-event .newsletter-form .newsletter-disclaimer {
        margin-top: 16px;
        padding: 0 30px;
        color: #d4dce5;
        font-size: 14px;
        line-height: 19px;
        text-align: center;
    }

    body.post-type-archive-news .newsletter-bg::after,
    body.single-news .newsletter-bg::after,
    body.post-type-archive-event .newsletter-bg::after,
    body.single-event .newsletter-bg::after {
        right: auto;
        bottom: auto;
        left: calc(50% + 46px);
        top: 128px;
        width: 380px;
        height: 520px;
        background-size: contain;
        background-position: left top;
        mix-blend-mode: normal;
        opacity: 1;
    }

    body.post-type-archive-event .gosuslugi-section,
    body.single-event .gosuslugi-section {
        padding: 72px 0;
        background: #f1f5f9;
    }

    body.post-type-archive-event .gosuslugi-section > .container-fluid,
    body.single-event .gosuslugi-section > .container-fluid {
        width: calc(100% - 40px);
        max-width: none;
        padding: 0;
    }

    body.post-type-archive-event .gosuslugi-content,
    body.single-event .gosuslugi-content {
        display: block;
    }

    body.post-type-archive-event .gosuslugi-card,
    body.single-event .gosuslugi-card {
        width: 100%;
        height: auto;
    }

    body.post-type-archive-event .footer-home-style,
    body.single-event .footer-home-style {
        background: #f1f5f9;
    }

    body.post-type-archive-event .footer-home-style .footer-main,
    body.single-event .footer-home-style .footer-main {
        padding: 0 0 72px;
    }

    body.post-type-archive-event .footer-home-style .footer-grid,
    body.single-event .footer-home-style .footer-grid {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        column-gap: 18px;
        row-gap: 44px;
    }

    body.post-type-archive-event .footer-home-style .footer-logo,
    body.single-event .footer-home-style .footer-logo,
    body.post-type-archive-event .footer-home-style .footer-home-legal,
    body.single-event .footer-home-style .footer-home-legal {
        grid-column: 1 / -1;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo,
    body.single-event .footer-home-style .footer-home-logo {
        width: 194px;
        gap: 13px;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo .logo-icon,
    body.single-event .footer-home-style .footer-home-logo .logo-icon {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo .logo-subtitle,
    body.single-event .footer-home-style .footer-home-logo .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
        color: #2c3e50;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo .logo-title,
    body.single-event .footer-home-style .footer-home-logo .logo-title {
        width: 130px;
        color: #0a3d62;
        font-size: 10.93px;
        line-height: 13px;
    }

    body.post-type-archive-event .footer-home-style .footer-nav ul,
    body.single-event .footer-home-style .footer-nav ul {
        min-height: 382px;
        gap: 0;
    }

    body.post-type-archive-event .footer-home-style .footer-nav a,
    body.single-event .footer-home-style .footer-nav a {
        font-size: 16px;
        line-height: 22px;
    }

    body.post-type-archive-event .footer-home-style .footer-contacts,
    body.single-event .footer-home-style .footer-contacts {
        gap: 36px;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-item,
    body.single-event .footer-home-style .footer-contact-item {
        grid-template-columns: 24px minmax(0, 1fr);
        column-gap: 8px;
        row-gap: 8px;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-item .contact-ui-icon,
    body.single-event .footer-home-style .footer-contact-item .contact-ui-icon {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-label,
    body.single-event .footer-home-style .footer-contact-label {
        font-size: 14px;
        line-height: 19px;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-value,
    body.post-type-archive-event .footer-home-style .footer-contact-value:hover,
    body.single-event .footer-home-style .footer-contact-value,
    body.single-event .footer-home-style .footer-contact-value:hover {
        font-size: 18px;
        line-height: 25px;
    }

    body.post-type-archive-event .footer-home-style .copyright-home,
    body.post-type-archive-event .footer-home-style .footer-home-legal a,
    body.single-event .footer-home-style .copyright-home,
    body.single-event .footer-home-style .footer-home-legal a {
        font-size: 16px;
        line-height: 22px;
    }
}

/* Финальная раскладка мобильной главной: порядок блоков как на скрине */
@media (max-width: 576px) {
    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid {
        display: flex;
        flex-direction: column;
    }

    body.home .news-section .section-header,
    body.home .directions-section .section-header {
        display: contents;
    }

    body.home .news-section .section-title,
    body.home .directions-section .section-title {
        order: 1;
        margin: 0 0 30px;
    }

    body.home .news-section .news-grid,
    body.home .directions-section .home-directions-grid {
        order: 2;
    }

    body.home .news-section .section-link,
    body.home .directions-section .section-link {
        order: 3;
        margin-top: 30px;
    }

    body.home .news-section {
        padding-top: 72px;
    }

    body.home .newsletter-section {
        margin-top: 72px;
    }

    body.home .directions-section {
        padding-top: 72px;
    }

    body.home .contact-form-section > .container-fluid {
        display: flex;
        flex-direction: column;
    }

    body.home .contact-form-wrapper,
    body.home .contact-form-info {
        display: contents;
    }

    body.home .contact-form-title {
        order: 1;
    }

    body.home .contact-form-description {
        order: 2;
    }

    body.home .contact-form-container {
        order: 3;
    }

    body.home .contact-form-image {
        order: 4;
        display: flex;
        justify-content: center;
        margin-top: 42px;
    }

    body.home .partners-section .section-header {
        gap: 12px;
        margin-bottom: 28px;
    }

    body.home .gosuslugi-section {
        margin-top: 72px;
    }
}

/* Точная подгонка hero-контролов под узкие мобильные ширины:
   320, 360, 375, 390, 412/414. */
@media (max-width: 389px) {
    body.home .hero-content .btn {
        width: 156px;
        min-width: 156px;
        height: 54px;
        min-height: 54px;
        padding: 0 18px;
        font-size: 14px;
        line-height: 24px;
    }

    body.home .hero-slider-controls {
        right: 10px;
        top: 333px;
        grid-template-columns: 20px 120px;
        gap: 6px;
        width: 146px;
        height: 54px;
    }

    body.home .hero-slider-counter {
        width: 20px;
        min-width: 20px;
        font-size: 13px;
        line-height: 20px;
    }

    body.home .hero-slider-arrows {
        gap: 6px;
    }

    body.home .hero-arrow {
        width: 54px;
        height: 54px;
        flex-basis: 54px;
    }

    body.home .hero-arrow svg {
        width: 11px;
        height: 17px;
    }
}

@media (max-width: 350px) {
    body.home .hero-content .btn {
        left: 20px;
        width: 130px;
        min-width: 130px;
        height: 48px;
        min-height: 48px;
        padding: 0 14px;
        font-size: 12px;
        line-height: 20px;
    }

    body.home .hero-slider-controls {
        left: auto;
        right: 10px;
        top: 336px;
        grid-template-columns: 18px 100px;
        gap: 4px;
        width: 122px;
        height: 48px;
    }

    body.home .hero-slider-counter {
        width: 18px;
        min-width: 18px;
        font-size: 12px;
        line-height: 18px;
    }

    body.home .hero-slider-arrows {
        gap: 4px;
    }

    body.home .hero-arrow {
        width: 48px;
        height: 48px;
        flex-basis: 48px;
    }

    body.home .hero-arrow svg {
        width: 10px;
        height: 16px;
    }
}

/* ==========================================================================
   Модальные окна направлений деятельности
   ========================================================================== */

.direction-modal-open {
    overflow: hidden;
}

.direction-modal {
    position: fixed;
    inset: 0;
    z-index: 3200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    overflow-y: auto;
}

.direction-modal.is-open {
    display: flex;
}

.direction-modal__backdrop {
    position: fixed;
    inset: 0;
    background: rgba(4, 31, 51, 0.72);
}

.direction-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(960px, 100%);
    max-height: min(760px, calc(100vh - 96px));
    padding: 72px 76px;
    overflow-y: auto;
    background: #0a3d62;
    color: #ffffff;
    box-shadow: 0 24px 80px rgba(4, 31, 51, 0.28);
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.direction-modal__dialog::-webkit-scrollbar {
    display: none;
}

.direction-modal__close {
    position: absolute;
    top: 34px;
    right: 34px;
    width: 18px;
    height: 18px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.direction-modal__close span {
    position: absolute;
    left: 0;
    top: 8px;
    width: 18px;
    height: 2px;
    background: #ffffff;
    transform-origin: center;
}

.direction-modal__close span:first-child {
    transform: rotate(-45deg);
}

.direction-modal__close span:last-child {
    transform: rotate(45deg);
}

.direction-modal__title {
    max-width: 740px;
    margin: 0 72px 72px 0;
    color: #ffffff;
    font-size: 22px;
    line-height: 28px;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.direction-modal__content {
    color: #ffffff;
    font-size: 16px;
    line-height: 1.45;
    font-weight: 400;
    letter-spacing: -0.02em;
}

.direction-modal__content p {
    margin: 0 0 24px;
}

.direction-modal__content p:last-child,
.direction-modal__content ul:last-child {
    margin-bottom: 0;
}

.direction-modal__content ul {
    margin: 0 0 28px;
    padding-left: 30px;
}

.direction-modal__content li + li {
    margin-top: 12px;
}

.direction-modal__content strong {
    font-weight: 700;
}

.direction-modal__content a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 3px;
}

@media (max-width: 768px) {
    .direction-modal {
        align-items: flex-start;
        padding: 20px 14px;
    }

    .direction-modal__dialog {
        max-height: calc(100vh - 40px);
        padding: 56px 24px 40px;
    }

    .direction-modal__close {
        top: 18px;
        right: 18px;
        width: 18px;
        height: 18px;
    }

    .direction-modal__close span {
        left: 0;
        top: 8px;
        width: 18px;
        height: 2px;
    }

    .direction-modal__title {
        margin: 0 42px 34px 0;
        font-size: 22px;
        line-height: 28px;
    }

    .direction-modal__content {
        font-size: 16px;
        line-height: 1.45;
    }

    .direction-modal__content ul {
        padding-left: 22px;
    }
}

/* ==========================================================================
   Адаптивные страховки для зума и промежуточных разрешений
   ========================================================================== */

html,
body {
    max-width: 100%;
    overflow-x: clip;
}

img,
svg,
video,
iframe {
    max-width: 100%;
}

.container,
.container-fluid {
    width: 100%;
}

.site-main,
.site-content,
.page,
.entry-content,
.inner-page-content {
    min-width: 0;
}

.main-navigation a,
.section-link,
.news-card-title,
.direction-title,
.partner-name,
.doc-link-card,
.info-card h3 {
    overflow-wrap: anywhere;
}

.btn,
.hero-content .btn {
    white-space: nowrap;
    overflow-wrap: normal;
}

.news-section .news-grid,
.directions-grid,
.partners-section .partners-grid,
.info-card-grid-4,
.info-card-grid-3,
.info-card-grid-2x2,
.doc-card-grid-3,
.doc-card-grid-2,
.cooperation-grid,
.reporting-grid,
.msp-support-grid {
    min-width: 0;
}

.news-card,
.direction-card,
.partner-card,
.doc-link-card,
.info-card,
.reporting-card,
.msp-support-card {
    max-width: 100%;
}

.news-card-image,
.news-card-image a,
.news-image,
.news-image-placeholder {
    max-width: 100%;
}

@media (max-width: 1360px) {
    .news-section .news-grid,
    .directions-grid,
    .partners-section .partners-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
    }

    .news-section .news-card,
    body.home .news-section .news-card,
    .direction-card,
    .partner-card {
        width: 100%;
    }

    .news-card-image,
    .news-card-image a,
    .news-image,
    .news-image-placeholder,
    body.home .news-section .news-card-image,
    body.home .news-section .news-card-image a,
    body.home .news-section .news-image,
    body.home .news-section .news-image-placeholder {
        width: 100%;
    }

    .doc-card-grid-2,
    .doc-card-grid-3 {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
    }

    .doc-link-card {
        width: 100%;
    }

    .hero-slider,
    .hero-content {
        width: calc(100% - 612px);
    }

    .hero-title {
        left: 80px;
        width: min(760px, calc(100% - 120px));
        font-size: clamp(42px, 3.7vw, 52px);
        line-height: 1.18;
    }

    .hero-content .btn {
        left: 80px;
    }

    .hero-slider-controls {
        right: calc(612px + 80px);
    }

    .hero-sidebar {
        width: 612px;
    }

    .hero-sidebar-card {
        width: 600px;
        padding: 0 48px;
    }
}

@media (max-width: 1200px) {
    .header-top-inner {
        grid-template-columns: minmax(220px, 254px) minmax(0, 1fr);
        gap: 28px;
    }

    .header-utility {
        gap: 18px;
    }

    .header-contacts {
        flex-wrap: wrap;
        justify-content: flex-start;
        gap: 12px 18px;
        margin-left: 0;
    }

    .header-contact-item a,
    .header-contact-item span,
    .header-contact-item .upriu-accessibility-toggle {
        white-space: normal;
    }

    .main-navigation ul {
        gap: 18px 24px;
        flex-wrap: wrap;
    }

    .contact-form-wrapper {
        gap: 64px;
        grid-template-columns: minmax(0, 1fr) minmax(360px, 638px);
    }

    .contact-form .form-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .hero-slider,
    .hero-content {
        width: calc(100% - 492px);
    }

    .hero-title {
        left: 48px;
        bottom: 214px;
        width: min(620px, calc(100% - 72px));
        font-size: clamp(34px, 3.6vw, 42px);
    }

    .hero-content .btn {
        left: 48px;
    }

    .hero-slider-controls {
        right: calc(492px + 48px);
    }

    .hero-sidebar {
        width: 492px;
    }

    .hero-sidebar-card {
        width: 480px;
        padding: 0 34px;
        gap: 24px;
    }
}

@media (max-width: 991px) {
    .header-top-inner {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 18px;
    }

    .header-logo {
        min-width: 0;
    }

    .site-logo.site-logo-with-text {
        max-width: 100%;
    }

    .site-logo.site-logo-with-text .logo-text {
        max-width: min(170px, calc(100vw - 150px));
    }

    .header-main {
        order: 0;
        width: auto;
        align-items: flex-end;
        gap: 0;
    }

    .header-utility {
        display: none;
    }

    .header-nav-row {
        width: auto;
        justify-content: flex-end;
    }

    .main-navigation {
        display: none;
        position: absolute;
        top: calc(100% - 24px);
        left: var(--container-padding, 20px);
        right: var(--container-padding, 20px);
        z-index: 1200;
        width: auto;
        padding: 22px;
        border-radius: 22px;
        background: #ffffff;
        box-shadow: 0 18px 46px rgba(10, 61, 98, 0.16);
    }

    .main-navigation.active {
        display: block;
    }

    .main-navigation ul,
    .main-navigation.active ul {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
        padding: 0;
    }

    .main-navigation .sub-menu,
    .main-navigation.active .sub-menu {
        position: static;
        display: block;
        min-width: 0;
        width: 100%;
        padding: 10px 0 0 14px;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
    }

    .header-drawer-meta,
    .main-navigation.active .header-drawer-meta {
        display: flex;
        flex-direction: column;
        gap: 18px;
        width: 100%;
        margin-top: 22px;
        padding-top: 18px;
        border-top: 1px solid rgba(12, 70, 115, 0.12);
    }

    .header-drawer-meta .header-search {
        width: 100%;
        max-width: 100%;
        flex: 1 1 auto;
    }

    .header-drawer-meta .header-contacts {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .hero-section {
        height: auto;
        min-height: 0;
        overflow: hidden;
    }

    .hero-slider,
    .hero-content,
    .hero-slide,
    .hero-slide.active {
        width: 100%;
        min-height: clamp(430px, 58vw, 620px);
    }

    .hero-slide-bg,
    .hero-bg-placeholder,
    .hero-overlay {
        height: clamp(430px, 58vw, 620px);
    }

    .hero-content {
        padding: 0;
    }

    .hero-title {
        left: clamp(20px, 6vw, 56px);
        bottom: clamp(128px, 18vw, 190px);
        width: min(620px, calc(100% - 40px));
        max-width: calc(100% - 40px);
        font-size: clamp(28px, 5.2vw, 40px);
        line-height: 1.18;
    }

    .hero-content .btn {
        left: clamp(20px, 6vw, 56px);
        bottom: 44px;
        min-width: 0;
        max-width: calc(100% - 40px);
    }

    .hero-slider-controls {
        right: clamp(20px, 6vw, 56px);
        left: auto;
        bottom: 44px;
    }

    .hero-sidebar {
        position: static;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: 100%;
        height: auto;
        padding: 12px;
    }

    .hero-sidebar-card {
        width: 100%;
        min-height: 128px;
        height: auto;
        padding: 24px;
    }
}

@media (max-width: 700px) {
    .hero-sidebar {
        grid-template-columns: 1fr;
    }

    .hero-title {
        bottom: 148px;
    }

    .hero-content .btn,
    .hero-slider-controls {
        bottom: 36px;
    }

    .hero-slider-controls {
        transform: scale(0.9);
        transform-origin: right center;
    }
}

@media (max-width: 576px) {
    html,
    body {
        overflow-x: hidden;
    }

    body:not(.home) .header-top {
        padding: 24px 0;
    }

    body:not(.home) .site-logo.site-logo-with-text {
        width: auto;
        height: 70px;
        gap: 12px;
    }

    body:not(.home) .site-logo.site-logo-with-text .logo-full,
    body:not(.home) .site-logo.site-logo-with-text .logo-full img {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    body:not(.home) .logo-subtitle {
        font-size: 9.13px;
    }

    body:not(.home) .logo-title {
        font-size: 10.93px;
        line-height: 13px;
    }

    body:not(.home) .hero-slider,
    body:not(.home) .hero-content,
    body:not(.home) .hero-slide,
    body:not(.home) .hero-slide.active,
    body:not(.home) .hero-slide-bg,
    body:not(.home) .hero-bg-placeholder,
    body:not(.home) .hero-overlay {
        min-height: 420px;
        height: 420px;
    }

    body:not(.home) .hero-title {
        top: auto;
        bottom: 132px;
        font-size: 28px;
        line-height: 34px;
    }

    body:not(.home) .hero-sidebar {
        display: none;
    }

    .form-actions .btn,
    .contact-section-button,
    .event-register-btn {
        width: 100%;
        min-width: 0;
    }
}

@supports not (overflow-x: clip) {
    html,
    body {
        overflow-x: hidden;
    }
}

/* ==========================================================================
   ТЗ: контрольные брейкпоинты 1400 / 1200 / 992 / 768 / 576 / 320
   ========================================================================== */

@media (max-width: 1400px) {
    :root {
        --adaptive-container-gutter: 64px;
    }

    .container,
    .container-fluid,
    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    .inner-page-content {
        width: 100%;
        max-width: 1310px;
        margin-right: auto;
        margin-left: auto;
        padding-right: 0;
        padding-left: 0;
    }

    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid {
        width: calc(100% - var(--adaptive-container-gutter));
        max-width: 1310px;
        padding-right: 0;
        padding-left: 0;
    }

    .cooperation-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 22px;
    }

    .cooperation-card,
    .reporting-card,
    .consumer-market-card,
    .msp-support-card,
    .info-card {
        width: 100%;
    }

    .reporting-grid,
    .consumer-market-grid,
    .msp-support-grid,
    .info-card-grid-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 22px;
    }

    .consumer-page-content .doc-card-grid-3,
    .support-navigator-grid.doc-card-grid-3,
    .financial-results-grid.doc-card-grid-3,
    .single-event-documents.doc-card-grid-2,
    .doc-card-grid-2 {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
        gap: 22px;
    }

    .consumer-page-content .doc-link-card,
    .support-navigator-grid .doc-link-card,
    .financial-results-grid .doc-link-card,
    .single-event-documents .doc-link-card,
    .doc-link-card {
        width: 100%;
    }

    .msp-hero-layout {
        grid-template-columns: minmax(0, 1fr) minmax(360px, 638px);
        gap: 48px;
    }

    .footer-grid,
    .footer-home-style .footer-grid {
        gap: 32px;
    }

    .header-top-inner {
        grid-template-columns: minmax(220px, 254px) minmax(0, 1fr);
        gap: 28px;
    }

    .header-utility {
        display: grid;
        grid-template-columns: minmax(240px, 312px) minmax(0, 1fr);
        gap: 12px 24px;
        align-items: center;
    }

    .header-search {
        width: 100%;
        max-width: 312px;
        flex: 1 1 auto;
    }

    .header-contacts {
        min-width: 0;
        flex-wrap: wrap;
        justify-content: flex-end;
        gap: 10px 18px;
        margin-left: 0;
    }

    .header-contact-item {
        min-width: 0;
    }

    .header-contact-item a,
    .header-contact-item span,
    .header-contact-item .upriu-accessibility-toggle {
        white-space: nowrap;
    }

    .header-nav-row {
        gap: 24px;
    }

    .main-navigation ul {
        gap: 18px 24px;
        flex-wrap: wrap;
    }

    .mobile-menu-toggle {
        margin-left: auto;
    }
}

@media (max-width: 1200px) {
    :root {
        --adaptive-container-gutter: 48px;
    }

    .header-utility {
        grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
    }

    .cooperation-grid,
    .reporting-grid,
    .consumer-market-grid,
    .msp-support-grid,
    .info-card-grid-3,
    .info-card-grid-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .footer-grid,
    .footer-home-style .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 48px 32px;
    }

    .msp-hero-layout,
    .contact-form-wrapper,
    .newsletter-content {
        grid-template-columns: 1fr;
    }

    .newsletter-form-container,
    .newsletter-form .newsletter-disclaimer {
        width: 100%;
        max-width: 420px;
    }

    .gosuslugi-image {
        right: -260px;
        width: min(70vw, 760px);
    }

    .gosuslugi-image img {
        width: 100%;
        max-width: 100%;
    }
}

@media (max-width: 992px) {
    :root {
        --adaptive-container-gutter: 40px;
    }

    .single-post-layout,
    .single-post-topline,
    .single-event-layout,
    .page-layout,
    .events-archive-layout,
    .about-page-layout {
        grid-template-columns: 1fr;
        gap: 36px;
    }

    .events-archive-sidebar,
    .page-sidebar,
    .single-post-sidebar,
    .single-event-sidebar {
        width: 100%;
        justify-self: stretch;
    }

    .section-side-nav {
        position: static;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .side-pill,
    .pill-tab {
        width: auto;
        min-width: 0;
        max-width: 100%;
        height: auto;
    }

    .consumer-page-content .pill-tabs {
        display: flex;
        flex-wrap: wrap;
    }

    .consumer-page-content .pill-tab {
        white-space: normal;
    }

    .event-list-item {
        grid-template-columns: minmax(0, 1fr);
        gap: 18px;
    }

    .event-list-actions {
        justify-self: stretch;
        align-items: stretch;
        width: 100%;
    }

    .event-list-actions .btn {
        width: 100%;
        min-width: 0;
    }

    .documents-table-head {
        display: none;
    }

    .documents-table-row {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .contact-modal__dialog,
    .consumer-market-modal__dialog {
        width: 100%;
        max-width: calc(100vw - 32px);
    }
}

@media (max-width: 768px) {
    :root {
        --adaptive-container-gutter: 32px;
    }

    .cooperation-grid,
    .reporting-grid,
    .consumer-market-grid,
    .msp-support-grid,
    .info-card-grid-3,
    .info-card-grid-4,
    .info-card-grid-2x2,
    .partners-grid-compact,
    .single-event-related-list {
        grid-template-columns: 1fr;
    }

    .info-card,
    .cooperation-card,
    .reporting-card,
    .consumer-market-card,
    .msp-support-card {
        min-height: 0;
        height: auto;
    }

    .info-card h3,
    .info-card a,
    .consumer-market-card-title,
    .consumer-market-card-link {
        position: static;
    }

    .info-card {
        display: flex;
        flex-direction: column;
        gap: 26px;
        padding: 30px;
    }

    .info-card-number {
        position: static;
    }

    .info-card h3 {
        max-width: 100%;
    }

    .info-card a {
        margin-top: auto;
    }

    .info-card-art {
        right: -56px;
        width: 190px;
        height: 190px;
    }

    .consumer-market-card {
        display: flex;
        flex-direction: column;
        gap: 26px;
        padding: 30px;
    }

    .consumer-market-card-title {
        max-width: 100%;
    }

    .consumer-market-card-link {
        margin-top: auto;
    }

    .single-event-details {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .single-event-image,
    .single-event-map,
    .single-post-image,
    .map-placeholder,
    .map-placeholder iframe,
    .map-placeholder-image {
        height: auto;
        min-height: 240px;
    }

    .contact-modal__row,
    .contact-modal__actions {
        grid-template-columns: 1fr;
    }

    .contact-modal__message,
    .contact-modal__actions .btn {
        width: 100%;
    }
}

@media (max-width: 576px) {
    .container,
    .container-fluid {
        width: 100%;
        max-width: 100%;
        padding-right: var(--container-padding);
        padding-left: var(--container-padding);
    }

    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid,
    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid {
        width: 100%;
    }

    .page-title,
    .archive-list-title,
    .blog-list-title,
    .single-post-title,
    .single-event-title,
    .section-title,
    .contact-form-title,
    .newsletter-title,
    .gosuslugi-title {
        overflow-wrap: anywhere;
    }

    .btn {
        white-space: normal;
    }

    .hero-content .btn {
        white-space: nowrap;
    }

    .contact-modal,
    .consumer-market-modal,
    .msp-support-modal,
    .direction-modal {
        padding-right: 14px;
        padding-left: 14px;
    }

    .contact-modal__dialog,
    .consumer-market-modal__dialog,
    .msp-support-modal__dialog,
    .direction-modal__dialog {
        max-width: calc(100vw - 28px);
    }

    .footer-grid,
    .footer-home-style .footer-grid {
        grid-template-columns: 1fr;
    }

    .home-contacts-card,
    .home-contacts-card .btn,
    .contact-section-button {
        width: 100%;
        min-width: 0;
    }
}

@media (max-width: 576px) {
    body.post-type-archive-document {
        background: #F1F5F9;
    }

    body.post-type-archive-document .site-main {
        background: #F1F5F9;
    }

    body.post-type-archive-document .documents-archive-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    body.post-type-archive-document .breadcrumbs {
        margin: 22px 0 28px;
        font-family: var(--font-secondary);
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
        letter-spacing: -0.02em;
        color: #A6B2C1;
    }

    body.post-type-archive-document .archive-list-title {
        margin: 0;
        font-family: var(--font-primary);
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #0A3D62;
    }

    body.post-type-archive-document .documents-toolbar {
        display: flex;
        flex-direction: column;
        gap: 18px;
        width: calc(100vw - 20px);
        margin: 22px -20px 32px 0;
        overflow: hidden;
    }

    body.post-type-archive-document .documents-tabs {
        display: flex;
        flex-wrap: nowrap;
        gap: 10px;
        width: 100%;
        padding-right: 20px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    body.post-type-archive-document .documents-tabs::-webkit-scrollbar {
        display: none;
    }

    body.post-type-archive-document .documents-tab {
        flex: 0 0 auto;
        min-height: 60px;
        padding: 14px 24px;
        border-radius: 60px;
        background: #fff;
        box-shadow: none;
        font-family: var(--font-secondary);
        font-size: 14px;
        font-weight: 400;
        line-height: 32px;
        letter-spacing: -0.02em;
        color: #2C3E50;
        white-space: nowrap;
    }

    body.post-type-archive-document .documents-tab.is-active {
        background: #2FB4BE;
        color: #fff;
    }

    body.post-type-archive-document .documents-search {
        width: calc(100vw - 40px);
    }

    body.post-type-archive-document .documents-search .form-control {
        width: 100%;
        height: 60px;
        min-height: 60px;
        padding: 18px 64px 18px 24px;
        border: 0;
        border-radius: 60px;
        background: #fff;
        font-family: var(--font-secondary);
        font-size: 14px;
        font-weight: 400;
        line-height: 24px;
        letter-spacing: -0.02em;
        color: #2C3E50;
        box-shadow: none;
    }

    body.post-type-archive-document .documents-search-submit {
        right: 24px;
    }

    body.post-type-archive-document .documents-table {
        gap: 0;
        padding-bottom: 70px;
    }

    body.post-type-archive-document .documents-table-head {
        display: none;
    }

    body.post-type-archive-document .documents-table-row {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        width: 100%;
        min-height: 220px;
        margin: 0 0 8px;
        padding: 30px;
        gap: 10px;
        background: #E8EEF3;
        color: #2C3E50;
    }

    body.post-type-archive-document .documents-table-row:nth-of-type(even) {
        background: #F1F5F9;
    }

    body.post-type-archive-document .documents-table-row:hover,
    body.post-type-archive-document .documents-table-row:focus-visible {
        background: #2FB4BE;
        color: #fff;
    }

    body.post-type-archive-document .documents-table-row span {
        display: block;
        width: 100%;
        font-family: var(--font-secondary);
        font-size: 18px;
        font-weight: 400;
        line-height: 26px;
        letter-spacing: -0.02em;
        color: inherit;
    }

    body.post-type-archive-document .documents-table-row span::before {
        font-weight: 700;
    }

    body.post-type-archive-document .documents-table-row span:nth-child(1)::before {
        content: "№ ";
    }

    body.post-type-archive-document .documents-table-row span:nth-child(2)::before {
        content: "Дата: ";
    }

    body.post-type-archive-document .documents-table-row span:nth-child(3)::before {
        content: "Название: ";
    }

    body.post-type-archive-document .documents-table-row span:nth-child(4)::before {
        content: "Вид: ";
    }

    body.post-type-archive-document .pagination {
        margin-top: 32px;
    }
}

@media (max-width: 360px) {
    :root {
        --container-padding: 16px;
    }

    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid,
    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid {
        padding-right: 16px;
        padding-left: 16px;
    }

    body.home .main-navigation {
        left: 16px;
        right: 16px;
    }

    body.home .hero-title,
    body:not(.home) .hero-title {
        width: calc(100vw - 32px);
        max-width: calc(100vw - 32px);
    }

    body.home .hero-content .btn {
        width: 142px;
        min-width: 142px;
        padding-right: 12px;
        padding-left: 12px;
    }

    .form-control,
    .event-select-button,
    .documents-tab,
    .side-pill,
    .pill-tab {
        padding-right: 20px;
        padding-left: 20px;
    }
}

@media (max-width: 320px) {
    :root {
        --container-padding: 12px;
    }

    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid,
    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid {
        padding-right: 12px;
        padding-left: 12px;
    }

    .hero-slider-controls {
        transform: scale(0.82);
    }

    body.home .hero-content .btn {
        width: 128px;
        min-width: 128px;
        font-size: 12px;
    }

    .btn {
        padding-right: 18px;
        padding-left: 18px;
    }
}

/* ==========================================================================
   Mobile Header And Menu
   ========================================================================== */

.single-post-sidebar-mobile-title,
.single-post-sidebar-news-title,
.single-post-all-news-link {
    display: none;
}

.fullscreen-menu__top-search,
.fullscreen-menu__mobile-search,
.fullscreen-menu__mobile-layout,
.fullscreen-menu__mobile-contact-button {
    display: none;
}

@media (max-width: 576px) {
    .site-header {
        position: relative;
        background: #f1f5f9;
    }

    .header-top {
        height: 130px;
        padding: 30px 0;
        background: #f1f5f9;
        overflow: hidden;
    }

    .header-top > .container-fluid {
        width: calc(100% - 60px);
        max-width: 420px;
        padding-right: 0;
        padding-left: 0;
    }

    .header-top-inner {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0;
        height: 70px;
    }

    .header-logo {
        min-width: 0;
        flex: 0 0 auto;
    }

    .site-logo.site-logo-with-text {
        gap: 13px;
        width: 194px;
        height: 70px;
    }

    .site-logo.site-logo-with-text .logo-full {
        width: 50px;
        height: 70px;
        flex: 0 0 50px;
    }

    .site-logo.site-logo-with-text .logo-full img {
        width: 50px;
        height: 70px;
    }

    .site-logo.site-logo-with-text .logo-text {
        gap: 6px;
        max-width: 130px;
    }

    .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
    }

    .logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
    }

    .header-main {
        width: auto;
        min-width: 82px;
        flex: 0 0 82px;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        gap: 30px;
        order: 0;
    }

    .header-utility {
        display: flex;
        width: 28px;
        max-width: 28px;
        flex: 0 0 28px;
        gap: 0;
        order: 0;
    }

    .header-utility .header-contacts {
        display: none !important;
    }

    .header-search {
        display: block;
        width: 28px;
        max-width: 28px;
        flex: 0 0 28px;
    }

    .search-form {
        min-height: 28px;
        padding: 0;
        background: transparent;
    }

    .search-field {
        position: absolute;
        width: 1px;
        height: 1px;
        opacity: 0;
        pointer-events: none;
    }

    .search-submit,
    .search-submit svg {
        width: 28px;
        height: 28px;
    }

    .header-nav-row {
        width: 24px;
        flex: 0 0 24px;
        justify-content: flex-end;
        order: 1;
    }

    .mobile-menu-toggle {
        display: flex;
        position: static;
        width: 24px;
        height: 20px;
        margin: 0;
    }

    .mobile-menu-toggle span:nth-child(2) {
        align-self: flex-end;
        width: 12px;
    }

    .main-navigation,
    .main-navigation.active {
        display: none;
    }

    .fullscreen-menu.is-open {
        display: block !important;
    }

    .fullscreen-menu {
        background: #0a3d62;
    }

    .fullscreen-menu__inner {
        width: calc(100% - 60px);
        max-width: 420px;
        min-height: 100svh;
        padding: 30px 0 70px;
    }

    .fullscreen-menu__top {
        display: grid;
        grid-template-columns: 194px 28px 24px;
        align-items: start;
        justify-content: space-between;
        min-height: 70px;
        border-bottom: 0;
    }

    .fullscreen-menu__logo {
        gap: 13px;
        width: 194px;
        height: 70px;
        margin: 0;
    }

    .fullscreen-menu__logo-icon {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    .fullscreen-menu__logo-text {
        gap: 6px;
    }

    .fullscreen-menu__logo-subtitle {
        width: 110px;
        margin: 0;
        font-size: 9.13px;
        line-height: 1.2;
    }

    .fullscreen-menu__logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
    }

    .fullscreen-menu__top-search {
        display: none;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        margin-top: 21px;
    }

    .fullscreen-menu__top-search svg {
        width: 28px;
        height: 28px;
    }

    .fullscreen-menu__close {
        width: 24px;
        height: 24px;
        margin-top: 23px;
    }

    .fullscreen-menu__close span {
        top: 11px;
        width: 24px;
        height: 2px;
    }

    .fullscreen-menu__mobile-search {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        height: 60px;
        margin-top: 90px;
        padding: 8px 28px;
        border-radius: 50px;
        background: #ffffff;
    }

    .fullscreen-menu__mobile-search-field {
        min-width: 0;
        flex: 1 1 auto;
        border: 0;
        outline: 0;
        background: transparent;
        color: #2c3e50;
        font-family: var(--font-secondary);
        font-size: 14px;
        line-height: 20px;
        letter-spacing: -0.02em;
    }

    .fullscreen-menu__mobile-search-field::placeholder {
        color: #2c3e50;
        opacity: 1;
    }

    .fullscreen-menu__mobile-search-submit {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        padding: 0;
        border: 0;
        background: transparent;
        cursor: pointer;
    }

    .fullscreen-menu__mobile-layout {
        display: grid;
        grid-template-columns: 124px minmax(0, 193px);
        justify-content: space-between;
        gap: 24px;
        margin-top: 60px;
    }

    .fullscreen-menu__mobile-nav {
        display: flex;
        flex-direction: column;
        gap: 20px;
    }

    .fullscreen-menu__mobile-nav a {
        color: #ffffff;
        font-family: var(--font-secondary);
        font-size: 16px;
        line-height: 22px;
        font-weight: 400;
        letter-spacing: -0.02em;
        text-decoration: none;
    }

    .fullscreen-menu__mobile-meta {
        display: flex;
        flex-direction: column;
        gap: 20px;
    }

    .fullscreen-menu__mobile-contact {
        display: flex;
        align-items: center;
        gap: 8px;
        min-width: 0;
        min-height: 28px;
    }

    .fullscreen-menu__mobile-contact svg,
    .fullscreen-menu__mobile-contact img {
        display: block;
        width: 28px;
        height: 28px;
        flex: 0 0 28px;
        object-fit: contain;
    }

    .fullscreen-menu__mobile-contact a,
    .fullscreen-menu__mobile-contact span,
    .fullscreen-menu__mobile-contact .upriu-accessibility-toggle {
        color: #ffffff;
        font-family: var(--font-secondary);
        font-size: 16px;
        line-height: 22px;
        font-weight: 600;
        letter-spacing: -0.02em;
        text-decoration: none;
        white-space: nowrap;
    }

    .fullscreen-menu__mobile-contact .upriu-accessibility-toggle {
        display: inline-flex;
        padding: 0;
        border: 0;
        background: transparent;
    }

    .fullscreen-menu__mobile-contact-button {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        min-height: 60px;
        margin-top: 60px;
        padding: 18px 40px;
        border: 0;
        border-radius: 60px;
        background: #2fb4be;
        color: #ffffff;
        font-family: var(--font-secondary);
        font-size: 16px;
        line-height: 24px;
        font-weight: 700;
        letter-spacing: -0.02em;
        cursor: pointer;
    }

    .fullscreen-menu__columns,
    .fullscreen-menu__contacts {
        display: none;
    }
}

@media (max-width: 380px) {
    .header-top > .container-fluid,
    .fullscreen-menu__inner {
        width: calc(100% - 32px);
    }

    .site-logo.site-logo-with-text,
    .fullscreen-menu__logo {
        width: 174px;
        gap: 10px;
    }

    .header-main {
        min-width: 76px;
        flex-basis: 76px;
        gap: 24px;
    }

    .fullscreen-menu__top {
        grid-template-columns: 174px 28px 24px;
    }

    .fullscreen-menu__mobile-layout {
        grid-template-columns: 1fr;
        gap: 42px;
    }

    .fullscreen-menu__mobile-search {
        margin-top: 70px;
    }
}

@media (max-width: 576px) {
    body.post-type-archive-news,
    body.single-news,
    body.post-type-archive-news .site-main,
    body.single-news .site-main {
        background: #f1f5f9;
    }

    body.post-type-archive-news .container-fluid,
    body.single-news .container-fluid {
        width: calc(100% - 60px);
        max-width: 420px;
        padding-right: 0;
        padding-left: 0;
    }

    body.post-type-archive-news .breadcrumbs,
    body.single-news .breadcrumbs {
        padding: 26px 0 34px;
        font-size: 12px;
        line-height: 16px;
        color: #a6b2c1;
    }

    body.post-type-archive-news .breadcrumbs a,
    body.single-news .breadcrumbs a {
        color: #a6b2c1;
    }

    body.post-type-archive-news .blog-list-section {
        padding: 0 0 72px;
        background: #f1f5f9;
    }

    body.post-type-archive-news .blog-list-header {
        margin-bottom: 60px;
    }

    body.post-type-archive-news .blog-list-title {
        margin: 0 0 30px;
        color: #0a3d62;
        font-size: 22px;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.post-type-archive-news .blog-list-toolbar,
    body.post-type-archive-news .blog-list-filters {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        gap: 16px;
    }

    body.post-type-archive-news .news-filter-category .news-filter-trigger,
    body.post-type-archive-news .news-filter-period .news-filter-trigger,
    body.post-type-archive-news .news-archive-trigger {
        width: 100%;
        min-width: 0;
        min-height: 60px;
        padding: 18px 56px 18px 30px;
        border-radius: 60px;
        font-size: 14px;
        line-height: 24px;
        box-shadow: none;
    }

    body.post-type-archive-news .news-filter-trigger::after {
        right: 30px;
    }

    body.post-type-archive-news .news-filter-trigger-label {
        font-size: 14px;
        line-height: 24px;
    }

    body.post-type-archive-news .news-filter-dropdown,
    body.post-type-archive-news .news-filter-panel,
    body.post-type-archive-news .news-archive-panel {
        width: 100%;
    }

    body.post-type-archive-news .news-filter-panel,
    body.post-type-archive-news .news-archive-panel {
        position: static;
        margin-top: 12px;
        padding: 20px;
        border-radius: 24px;
        overflow: hidden;
    }

    body.post-type-archive-news .news-filter-panel-grid {
        width: 100%;
        min-width: 0;
    }

    body.post-type-archive-news .news-filter-field,
    body.post-type-archive-news .news-filter-field .form-control {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }

    body.post-type-archive-news .news-filter-field .form-control {
        height: 52px;
        min-height: 52px;
        padding: 12px 18px;
        border-radius: 18px;
        -webkit-appearance: none;
        appearance: none;
        font-size: 16px;
        line-height: 24px;
    }

    body.post-type-archive-news .news-filter-field .form-control::-webkit-date-and-time-value {
        min-height: 24px;
        text-align: left;
    }

    body.post-type-archive-news .news-filter-archive {
        width: 100%;
        margin-left: 0;
    }

    body.post-type-archive-news .news-archive-trigger {
        justify-content: center;
        margin-top: 16px;
        padding-right: 30px;
        background: #2fb4be;
        color: #ffffff;
        font-size: 16px;
        line-height: 24px;
        font-weight: 700;
    }

    body.post-type-archive-news .news-archive-trigger::after {
        display: none;
    }

    body.post-type-archive-news .news-filter-actions {
        gap: 10px;
        margin-top: 16px;
    }

    body.post-type-archive-news .news-filter-apply {
        min-width: 142px;
        min-height: 50px;
        padding: 12px 24px;
        font-size: 16px;
        line-height: 22px;
    }

    body.post-type-archive-news .news-filter-reset {
        font-size: 13px;
        line-height: 18px;
    }

    body.post-type-archive-news .blog-list-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        margin-bottom: 58px;
    }

    body.post-type-archive-news .blog-list-grid .news-card {
        display: grid;
        grid-template-columns: 170px minmax(0, 1fr);
        width: 100%;
        height: 220px;
        min-height: 220px;
        max-height: 220px;
        border-radius: 0;
        box-shadow: none;
        overflow: hidden;
    }

    body.post-type-archive-news .blog-list-grid .news-card:hover {
        transform: none;
        box-shadow: none;
    }

    body.post-type-archive-news .blog-list-grid .news-card-image,
    body.post-type-archive-news .blog-list-grid .news-card-image a,
    body.post-type-archive-news .blog-list-grid .news-image,
    body.post-type-archive-news .blog-list-grid .news-image-placeholder {
        width: 170px;
        height: 220px;
    }

    body.post-type-archive-news .blog-list-grid .news-card-body {
        display: flex;
        flex-direction: column;
        min-width: 0;
        height: 220px;
        padding: 28px 24px 24px 30px;
    }

    body.post-type-archive-news .news-card-date,
    body.single-news .news-card-date {
        margin-bottom: 18px;
        gap: 8px;
        color: #a6b2c1;
        font-size: 14px;
        line-height: 19px;
        font-weight: 600;
    }

    body.post-type-archive-news .news-card-date svg,
    body.single-news .news-card-date svg {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }

    body.post-type-archive-news .news-card-title {
        display: -webkit-box;
        min-height: 72px;
        margin: 0;
        overflow: hidden;
        color: #2c3e50;
        font-size: 16px;
        line-height: 24px;
        letter-spacing: -0.02em;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }

    body.post-type-archive-news .news-card-category,
    body.single-news .news-card-category {
        margin-top: auto;
        color: #2fb4be;
        font-size: 14px;
        line-height: 22px;
        font-weight: 600;
    }

    body.post-type-archive-news .pagination {
        margin-top: 0;
    }

    body.post-type-archive-news .pagination .nav-links {
        gap: 12px;
    }

    body.post-type-archive-news .pagination .page-numbers {
        width: 58px;
        height: 58px;
        font-size: 16px;
        line-height: 22px;
    }

    body.single-news .single-post-section {
        padding: 0 0 72px;
        background: #f1f5f9;
    }

    body.single-news .single-post-topline,
    body.single-news .single-post-layout {
        display: block;
        margin-bottom: 0;
    }

    body.single-news .single-post-header {
        margin-bottom: 18px;
    }

    body.single-news .single-post-title {
        max-width: 390px;
        margin: 0 0 18px;
        color: #0a3d62;
        font-size: 22px;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.single-news .single-post-meta {
        gap: 30px;
        padding-top: 0;
        margin-bottom: 20px;
    }

    body.single-news .single-post-date,
    body.single-news .single-post-category {
        font-size: 14px;
        line-height: 19px;
        font-weight: 600;
    }

    body.single-news .single-post-date svg {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }

    body.single-news .single-post-sidebar-heading {
        display: none;
    }

    body.single-news .single-post-content {
        max-width: 100%;
    }

    body.single-news .single-post-image {
        width: 100%;
        height: 300px;
        max-width: 100%;
        margin-bottom: 34px;
    }

    body.single-news .single-post-image .post-image {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    body.single-news .single-post-body {
        max-width: 100%;
        margin-bottom: 54px;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-style: normal;
        font-weight: 400;
        line-height: 24px;
        letter-spacing: -0.02em;
    }

    body.single-news .single-lead-title {
        margin: 0 0 24px;
        color: #2c3e50;
        font-family: var(--font-primary);
        font-size: 18px;
        line-height: 23px;
        font-weight: 700;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.single-news .single-post-body p {
        margin-bottom: 22px;
    }

    body.single-news .content-section-block {
        margin-bottom: 0;
    }

    body.single-news .content-section-title,
    body.single-news .single-post-sidebar-mobile-title {
        margin: 0 0 28px;
        color: #2c3e50;
        font-family: var(--font-primary);
        font-size: 18px;
        line-height: 23px;
        font-weight: 700;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.single-news .single-news-documents {
        margin-top: 0;
        margin-bottom: 54px;
    }

    body.single-news .single-news-extra {
        margin-top: 0;
        margin-bottom: 54px;
    }

    body.single-news .single-news-extra .content-section-title {
        margin-bottom: 18px;
    }

    body.single-news .single-news-extra-link {
        margin-bottom: 18px;
        font-size: 16px;
        line-height: 24px;
    }

    body.single-news .single-news-extra-text {
        max-width: 100%;
        font-size: 16px;
        line-height: 24px;
    }

    body.single-news .single-news-documents .doc-card-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
    }

    body.single-news .doc-link-card {
        width: 100%;
        min-width: 0;
        height: 80px;
        min-height: 80px;
        gap: 8px;
        padding: 20px 18px;
    }

    body.single-news .doc-icon,
    body.single-news .doc-icon img {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }

    body.single-news .doc-link-card span:last-child {
        font-size: 10px;
        line-height: 14px;
        font-weight: 700;
    }

    body.single-news .single-post-content .partners-grid-compact {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
        align-items: start;
        margin: 0;
    }

    body.single-news .single-post-content .partners-grid-compact .partner-card {
        width: 100%;
        min-width: 0;
        height: 95px;
        min-height: 95px;
        padding: 20px 22px;
        background: #ffffff;
        border-radius: 0;
        overflow: hidden;
        transform: none;
        box-shadow: none;
    }

    body.single-news .single-post-content .partners-grid-compact .partner-logo {
        display: block;
        width: auto;
        max-width: 100%;
        max-height: 50px;
        margin: 0;
        object-fit: contain;
    }

    body.single-news .single-post-content .partners-grid-compact .partner-logo-placeholder {
        margin: 0;
    }

    body.single-news .single-post-content .partners-grid-compact .partner-card:nth-child(n+4) {
        display: none;
    }

    body.single-news .single-news-partners {
        display: block;
        clear: both;
        margin-bottom: 64px;
    }

    body.single-news .single-news-partners .content-section-title {
        margin-bottom: 28px;
    }

    body.single-news .single-post-sidebar {
        display: block;
        clear: both;
        margin-top: 0;
    }

    body.single-news .single-post-sidebar .sidebar-widget {
        padding: 0;
        background: transparent;
        margin-top: 0 !important;
    }

    body.single-news .single-post-sidebar-mobile-title,
    body.single-news .single-post-sidebar-news-title,
    body.single-news .single-post-all-news-link {
        display: flex;
    }

    body.single-news .single-post-sidebar-mobile-title,
    body.single-news .single-post-sidebar-news-title {
        margin-bottom: 28px;
    }

    body.single-news .single-post-sidebar .other-news-list {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        grid-template-columns: none;
        gap: 16px;
        align-items: start;
        width: calc(100vw - 20px);
        margin-right: -20px;
        overflow-x: auto;
        overscroll-behavior-x: contain;
        scroll-snap-type: x proximity;
        scrollbar-width: none;
    }

    body.single-news .single-post-sidebar .other-news-list::-webkit-scrollbar {
        display: none;
    }

    body.single-news .single-post-sidebar .other-news-card.news-card {
        width: 274px;
        min-width: 274px;
        height: auto;
        min-height: 0;
        max-height: none;
        background: #ffffff;
        border-radius: 0;
        overflow: hidden;
        transform: none;
        box-shadow: none;
        scroll-snap-align: start;
    }

    body.single-news .single-post-sidebar .other-news-card.news-card:nth-child(n+3) {
        display: block;
    }

    body.single-news .single-post-sidebar .other-news-card .news-card-image,
    body.single-news .single-post-sidebar .other-news-card .news-card-image a,
    body.single-news .single-post-sidebar .other-news-card .news-image,
    body.single-news .single-post-sidebar .other-news-card .news-image-placeholder {
        width: 100%;
        height: auto;
        aspect-ratio: 1 / 0.92;
    }

    body.single-news .single-post-sidebar .other-news-card .news-card-body {
        display: flex;
        flex-direction: column;
        height: auto;
        min-height: 210px;
        padding: 26px 24px 24px;
    }

    body.single-news .single-post-sidebar .other-news-card .news-card-title {
        display: -webkit-box;
        margin: 0;
        overflow: hidden;
        color: #2c3e50;
        font-size: 18px;
        line-height: 28px;
        font-weight: 700;
        letter-spacing: -0.02em;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }

    body.single-news .single-post-all-news-link {
        align-items: center;
        gap: 8px;
        width: max-content;
        margin-top: 28px;
        color: #2c3e50;
        font-size: 14px;
        line-height: 20px;
        font-weight: 700;
        text-decoration: none;
    }

    body.post-type-archive-news .newsletter-section,
    body.single-news .newsletter-section {
        position: relative;
        height: 520px;
        min-height: 520px;
        padding: 0;
        overflow: hidden;
        background: #0a3d62;
    }

    body.post-type-archive-news .newsletter-section > .container-fluid,
    body.single-news .newsletter-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding: 0 30px;
    }

    body.post-type-archive-news .newsletter-bg,
    body.single-news .newsletter-bg {
        display: block;
        z-index: 1;
    }

    body.post-type-archive-news .newsletter-bg::after,
    body.single-news .newsletter-bg::after {
        right: auto;
        bottom: auto;
        left: calc(50% + 46px);
        top: 128px;
        width: 380px;
        height: 520px;
        background: url("../images/logohomepodpiskabanner.png") left top / contain no-repeat;
        mix-blend-mode: normal;
        opacity: 1;
    }

    body.post-type-archive-news .newsletter-overlay,
    body.single-news .newsletter-overlay {
        display: none;
    }

    body.post-type-archive-news .newsletter-content,
    body.single-news .newsletter-content {
        position: static;
        display: block;
    }

    body.post-type-archive-news .newsletter-info,
    body.single-news .newsletter-info {
        display: contents;
    }

    body.post-type-archive-news .newsletter-title,
    body.single-news .newsletter-title {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 80px;
        width: calc(100% - 60px);
        max-width: 422px;
        margin: 0;
        color: #ffffff;
        font-size: 22px;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.post-type-archive-news .newsletter-description,
    body.single-news .newsletter-description {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 194px;
        width: calc(100% - 60px);
        max-width: 347px;
        margin: 0;
        color: #ffffff;
        font-size: 16px;
        line-height: 28px;
    }

    body.post-type-archive-news .newsletter-form-container,
    body.single-news .newsletter-form-container {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 254px;
        width: calc(100% - 60px);
        max-width: none;
        padding: 0;
        background: transparent;
    }

    body.post-type-archive-news .newsletter-form,
    body.single-news .newsletter-form {
        gap: 0;
    }

    body.post-type-archive-news .newsletter-form .form-control,
    body.single-news .newsletter-form .form-control {
        height: 60px;
        min-height: 60px;
        padding: 14px 32px;
        border-radius: 60px;
        background: #f1f5f9;
        font-size: 16px;
        line-height: 32px;
    }

    body.post-type-archive-news .newsletter-form .btn,
    body.single-news .newsletter-form .btn {
        width: 100%;
        min-width: 0;
        height: 60px;
        min-height: 60px;
        margin-top: 12px;
        padding: 14px 40px;
        border-radius: 60px;
        font-size: 16px;
        line-height: 32px;
        font-weight: 700;
    }

    body.post-type-archive-news .newsletter-form .newsletter-disclaimer,
    body.single-news .newsletter-form .newsletter-disclaimer {
        width: 100%;
        max-width: 100%;
        margin-top: 16px;
        padding: 0 30px;
        color: #d4dce5;
        font-size: 14px;
        line-height: 19px;
        text-align: center;
    }

    body.post-type-archive-news .footer-home-style,
    body.single-news .footer-home-style {
        background: #f1f5f9;
    }

    body.post-type-archive-news .footer-home-style .footer-main,
    body.single-news .footer-home-style .footer-main {
        padding: 80px 0 72px;
    }

    body.post-type-archive-news .footer-home-style .footer-grid,
    body.single-news .footer-home-style .footer-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 66px 32px;
        min-height: 0;
        align-items: start;
    }

    body.post-type-archive-news .footer-home-style .footer-app,
    body.single-news .footer-home-style .footer-app {
        order: 0;
        grid-column: 1 / -1;
        min-height: 0;
        justify-content: center;
    }

    body.post-type-archive-news .footer-gosuslugi-widget iframe,
    body.single-news .footer-gosuslugi-widget iframe {
        width: 420px;
        max-width: 100%;
        height: 450px;
        margin: 0 auto;
    }

    body.post-type-archive-news .footer-home-style .footer-about,
    body.single-news .footer-home-style .footer-about {
        order: 1;
        grid-column: 1 / -1;
        min-height: 0;
        display: contents;
    }

    body.post-type-archive-news .footer-home-style .footer-logo,
    body.single-news .footer-home-style .footer-logo {
        order: 1;
        grid-column: 1 / -1;
    }

    body.post-type-archive-news .footer-home-style .footer-home-logo,
    body.single-news .footer-home-style .footer-home-logo {
        width: 194px;
        gap: 13px;
    }

    body.post-type-archive-news .footer-home-style .footer-home-logo .logo-icon,
    body.single-news .footer-home-style .footer-home-logo .logo-icon {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    body.post-type-archive-news .footer-home-style .footer-home-logo .logo-subtitle,
    body.single-news .footer-home-style .footer-home-logo .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
        color: #2c3e50;
    }

    body.post-type-archive-news .footer-home-style .footer-home-logo .logo-title,
    body.single-news .footer-home-style .footer-home-logo .logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
        color: #0a3d62;
    }

    body.post-type-archive-news .footer-home-style .footer-nav,
    body.single-news .footer-home-style .footer-nav {
        order: 2;
        grid-column: 1;
        min-height: 0;
    }

    body.post-type-archive-news .footer-home-style .footer-nav ul,
    body.single-news .footer-home-style .footer-nav ul {
        min-height: 382px;
        gap: 0;
    }

    body.post-type-archive-news .footer-home-style .footer-nav a,
    body.single-news .footer-home-style .footer-nav a {
        font-size: 16px;
        line-height: 22px;
    }

    body.post-type-archive-news .footer-home-style .footer-contacts,
    body.single-news .footer-home-style .footer-contacts {
        order: 3;
        grid-column: 2;
        min-height: 0;
        gap: 36px;
        justify-content: flex-start;
    }

    body.post-type-archive-news .footer-home-style .footer-contact-item,
    body.single-news .footer-home-style .footer-contact-item {
        grid-template-columns: 24px minmax(0, 1fr);
        column-gap: 8px;
        row-gap: 8px;
    }

    body.post-type-archive-news .footer-home-style .footer-contact-item .contact-ui-icon,
    body.single-news .footer-home-style .footer-contact-item .contact-ui-icon {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    body.post-type-archive-news .footer-home-style .footer-contact-label,
    body.single-news .footer-home-style .footer-contact-label {
        font-size: 14px;
        line-height: 19px;
    }

    body.post-type-archive-news .footer-home-style .footer-contact-value,
    body.post-type-archive-news .footer-home-style .footer-contact-value:hover,
    body.single-news .footer-home-style .footer-contact-value,
    body.single-news .footer-home-style .footer-contact-value:hover {
        font-size: 18px;
        line-height: 25px;
    }

    body.post-type-archive-news .footer-home-style .footer-home-legal,
    body.single-news .footer-home-style .footer-home-legal {
        order: 4;
        grid-column: 1 / -1;
        max-width: 243px;
    }

    body.post-type-archive-news .footer-home-style .copyright-home,
    body.post-type-archive-news .footer-home-style .footer-home-legal a,
    body.single-news .footer-home-style .copyright-home,
    body.single-news .footer-home-style .footer-home-legal a {
        font-size: 16px;
        line-height: 22px;
    }

    body.post-type-archive-event .footer-home-style,
    body.single-event .footer-home-style {
        background: #f1f5f9;
    }

    body.post-type-archive-event .footer-home-style .footer-main,
    body.single-event .footer-home-style .footer-main {
        padding: 80px 0 72px;
    }

    body.post-type-archive-event .footer-home-style .footer-grid,
    body.single-event .footer-home-style .footer-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 66px 32px;
        min-height: 0;
        align-items: start;
    }

    body.post-type-archive-event .footer-home-style .footer-app,
    body.single-event .footer-home-style .footer-app {
        order: 0;
        grid-column: 1 / -1;
        min-height: 0;
        justify-content: center;
    }

    body.post-type-archive-event .footer-gosuslugi-widget iframe,
    body.single-event .footer-gosuslugi-widget iframe {
        width: 420px;
        max-width: 100%;
        height: 450px;
        margin: 0 auto;
    }

    body.post-type-archive-event .footer-home-style .footer-about,
    body.single-event .footer-home-style .footer-about {
        order: 1;
        grid-column: 1 / -1;
        min-height: 0;
        display: contents;
    }

    body.post-type-archive-event .footer-home-style .footer-logo,
    body.single-event .footer-home-style .footer-logo {
        order: 1;
        grid-column: 1 / -1;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo,
    body.single-event .footer-home-style .footer-home-logo {
        width: 194px;
        gap: 13px;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo .logo-icon,
    body.single-event .footer-home-style .footer-home-logo .logo-icon {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo .logo-subtitle,
    body.single-event .footer-home-style .footer-home-logo .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
        color: #2c3e50;
    }

    body.post-type-archive-event .footer-home-style .footer-home-logo .logo-title,
    body.single-event .footer-home-style .footer-home-logo .logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
        color: #0a3d62;
    }

    body.post-type-archive-event .footer-home-style .footer-nav,
    body.single-event .footer-home-style .footer-nav {
        order: 2;
        grid-column: 1;
        min-height: 0;
    }

    body.post-type-archive-event .footer-home-style .footer-nav ul,
    body.single-event .footer-home-style .footer-nav ul {
        min-height: 382px;
        gap: 0;
    }

    body.post-type-archive-event .footer-home-style .footer-nav a,
    body.single-event .footer-home-style .footer-nav a {
        font-size: 16px;
        line-height: 22px;
    }

    body.post-type-archive-event .footer-home-style .footer-contacts,
    body.single-event .footer-home-style .footer-contacts {
        order: 3;
        grid-column: 2;
        min-height: 0;
        gap: 36px;
        justify-content: flex-start;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-item,
    body.single-event .footer-home-style .footer-contact-item {
        grid-template-columns: 24px minmax(0, 1fr);
        column-gap: 8px;
        row-gap: 8px;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-item .contact-ui-icon,
    body.single-event .footer-home-style .footer-contact-item .contact-ui-icon {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-label,
    body.single-event .footer-home-style .footer-contact-label {
        font-size: 14px;
        line-height: 19px;
    }

    body.post-type-archive-event .footer-home-style .footer-contact-value,
    body.post-type-archive-event .footer-home-style .footer-contact-value:hover,
    body.single-event .footer-home-style .footer-contact-value,
    body.single-event .footer-home-style .footer-contact-value:hover {
        font-size: 18px;
        line-height: 25px;
    }

    body.post-type-archive-event .footer-home-style .footer-home-legal,
    body.single-event .footer-home-style .footer-home-legal {
        order: 4;
        grid-column: 1 / -1;
        max-width: 243px;
    }

    body.post-type-archive-event .footer-home-style .copyright-home,
    body.post-type-archive-event .footer-home-style .footer-home-legal a,
    body.single-event .footer-home-style .copyright-home,
    body.single-event .footer-home-style .footer-home-legal a {
        font-size: 16px;
        line-height: 22px;
    }
}

@media (max-width: 380px) {
    body.post-type-archive-news .container-fluid,
    body.single-news .container-fluid,
    body.post-type-archive-event .container-fluid,
    body.single-event .container-fluid {
        width: calc(100% - 32px);
    }

    body.post-type-archive-news .blog-list-grid .news-card {
        grid-template-columns: 120px minmax(0, 1fr);
        height: 200px;
        min-height: 200px;
        max-height: 200px;
    }

    body.post-type-archive-news .blog-list-grid .news-card-image,
    body.post-type-archive-news .blog-list-grid .news-card-image a,
    body.post-type-archive-news .blog-list-grid .news-image,
    body.post-type-archive-news .blog-list-grid .news-image-placeholder {
        width: 120px;
        height: 200px;
    }

    body.post-type-archive-news .blog-list-grid .news-card-body {
        height: 200px;
        padding: 20px 16px;
    }

    body.post-type-archive-news .pagination .nav-links {
        gap: 8px;
    }

    body.post-type-archive-news .pagination .page-numbers {
        width: 44px;
        height: 44px;
    }

    body.single-news .single-news-documents .doc-card-grid,
    body.single-news .single-post-content .partners-grid-compact,
    body.single-news .single-post-sidebar .other-news-list,
    body.post-type-archive-news .footer-home-style .footer-grid,
    body.single-news .footer-home-style .footer-grid,
    body.post-type-archive-event .footer-home-style .footer-grid,
    body.single-event .footer-home-style .footer-grid {
        grid-template-columns: 1fr;
    }

    body.post-type-archive-news .footer-home-style .footer-nav,
    body.post-type-archive-news .footer-home-style .footer-contacts,
    body.single-news .footer-home-style .footer-nav,
    body.single-news .footer-home-style .footer-contacts,
    body.post-type-archive-event .footer-home-style .footer-nav,
    body.post-type-archive-event .footer-home-style .footer-contacts,
    body.single-event .footer-home-style .footer-nav,
    body.single-event .footer-home-style .footer-contacts {
        grid-column: 1;
    }
}

@media (min-width: 577px) and (max-width: 1400px) {
    body.home .home-contacts-map > .container-fluid {
        width: calc(100% - 40px);
        max-width: 1310px;
        padding-right: 0;
        padding-left: 0;
    }

    body.home .home-contacts-card {
        width: min(526px, 52vw);
        min-width: 460px;
        transform: none;
    }

    body.home .home-contacts-card .btn {
        min-width: 0;
        width: 100%;
    }
}

/* Final mobile gutter override: every mobile page keeps 20px from viewport edges. */
@media (max-width: 576px) {
    :root {
        --adaptive-container-gutter: 40px;
        --container-padding: 20px;
    }

    .container,
    .container-fluid,
    body.post-type-archive-news .container-fluid,
    body.single-news .container-fluid,
    .header-top > .container-fluid,
    .fullscreen-menu__inner {
        width: calc(100% - 40px);
        max-width: none;
        padding-right: 0;
        padding-left: 0;
    }

    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid,
    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid,
    body.post-type-archive-news .newsletter-section > .container-fluid,
    body.single-news .newsletter-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    body.home .newsletter-title,
    body.home .newsletter-description,
    body.home .newsletter-form-container,
    body.post-type-archive-news .newsletter-title,
    body.post-type-archive-news .newsletter-description,
    body.post-type-archive-news .newsletter-form-container,
    body.single-news .newsletter-title,
    body.single-news .newsletter-description,
    body.single-news .newsletter-form-container {
        left: 20px;
        width: calc(100% - 40px);
    }

    body.home .newsletter-section,
    body.post-type-archive-news .newsletter-section,
    body.single-news .newsletter-section,
    body.post-type-archive-event .newsletter-section,
    body.single-event .newsletter-section {
        background: #0a3d62;
    }

    body.home .newsletter-content,
    body.post-type-archive-news .newsletter-content,
    body.single-news .newsletter-content,
    body.post-type-archive-event .newsletter-content,
    body.single-event .newsletter-content {
        position: static;
        z-index: auto;
    }

    body.home .newsletter-form-container,
    body.post-type-archive-news .newsletter-form-container,
    body.single-news .newsletter-form-container,
    body.post-type-archive-event .newsletter-form-container,
    body.single-event .newsletter-form-container {
        z-index: 3;
    }

    body.post-type-archive-event .newsletter-title,
    body.single-event .newsletter-title {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 80px;
        width: calc(100% - 60px);
        max-width: 422px;
        margin: 0;
        text-transform: uppercase;
    }

    body.post-type-archive-event .newsletter-description,
    body.single-event .newsletter-description {
        position: absolute;
        z-index: 2;
        left: 30px;
        top: 194px;
        width: calc(100% - 60px);
        max-width: 347px;
        margin: 0;
    }

    body.post-type-archive-event .newsletter-form-container,
    body.single-event .newsletter-form-container {
        position: absolute;
        left: 30px;
        top: 254px;
        width: calc(100% - 60px);
        max-width: none;
        padding: 0;
        background: transparent;
    }

    body.home .newsletter-form .form-control,
    body.home .newsletter-form .btn,
    body.post-type-archive-news .newsletter-form .form-control,
    body.post-type-archive-news .newsletter-form .btn,
    body.single-news .newsletter-form .form-control,
    body.single-news .newsletter-form .btn,
    body.post-type-archive-event .newsletter-form .form-control,
    body.post-type-archive-event .newsletter-form .btn,
    body.single-event .newsletter-form .form-control,
    body.single-event .newsletter-form .btn {
        width: 100%;
        height: 60px;
        min-height: 60px;
        max-width: none;
        border-radius: 60px;
    }

    body.home .newsletter-form .form-control,
    body.post-type-archive-news .newsletter-form .form-control,
    body.single-news .newsletter-form .form-control,
    body.post-type-archive-event .newsletter-form .form-control,
    body.single-event .newsletter-form .form-control {
        padding: 18px 32px;
        font-size: 16px;
        line-height: 32px;
    }

    body.home .newsletter-form .btn,
    body.post-type-archive-news .newsletter-form .btn,
    body.single-news .newsletter-form .btn,
    body.post-type-archive-event .newsletter-form .btn,
    body.single-event .newsletter-form .btn {
        margin-top: 12px;
        padding: 18px 40px;
        font-size: 16px;
        line-height: 32px;
        font-weight: 700;
    }

    body.home .newsletter-title,
    body.home .newsletter-description,
    body.home .newsletter-form-container,
    body.post-type-archive-news .newsletter-title,
    body.post-type-archive-news .newsletter-description,
    body.post-type-archive-news .newsletter-form-container,
    body.single-news .newsletter-title,
    body.single-news .newsletter-description,
    body.single-news .newsletter-form-container,
    body.post-type-archive-event .newsletter-title,
    body.post-type-archive-event .newsletter-description,
    body.post-type-archive-event .newsletter-form-container,
    body.single-event .newsletter-title,
    body.single-event .newsletter-description,
    body.single-event .newsletter-form-container {
        left: 30px;
        width: calc(100% - 60px);
    }

    body.home .newsletter-form .newsletter-disclaimer,
    body.post-type-archive-news .newsletter-form .newsletter-disclaimer,
    body.single-news .newsletter-form .newsletter-disclaimer,
    body.post-type-archive-event .newsletter-form .newsletter-disclaimer,
    body.single-event .newsletter-form .newsletter-disclaimer {
        display: block;
        position: relative;
        z-index: 4;
        width: 100%;
        max-width: 361px;
        margin: 16px auto 0;
        padding: 0;
        color: #d4dce5;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 19px;
        letter-spacing: -0.02em;
        text-align: center;
    }

    body.home .news-section .news-grid,
    body.single-news .single-post-sidebar .other-news-list {
        width: calc(100vw - 20px);
        margin-right: -20px;
    }

    body.home .home-contacts-map {
        min-height: 700px;
        padding: 30px 0;
    }

    body.home .home-contacts-map-embed iframe {
        height: 700px;
    }

    body.home .home-contacts-card {
        width: 100%;
        min-width: 0;
        max-width: none;
        min-height: 312px;
        height: auto;
        padding: 30px;
        background: #fff;
        box-shadow: none;
        transform: none;
    }

    body.home .home-contacts-card .content-section-title {
        margin-bottom: 30px;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-style: normal;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    body.home .home-contacts-list {
        gap: 16px;
        margin-bottom: 30px;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-style: normal;
        font-weight: 400;
        line-height: 24px;
        letter-spacing: -0.02em;
    }

    body.home .home-contacts-item {
        gap: 16px;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-style: normal;
        font-weight: 400;
        line-height: 24px;
        letter-spacing: -0.02em;
    }

    body.home .home-contacts-icon,
    body.home .home-contacts-icon img {
        width: 28px;
        height: 28px;
        flex: 0 0 28px;
    }

    body.home .home-contacts-card .btn {
        width: 100%;
        min-width: 0;
        min-height: 60px;
        padding: 18px 40px;
        border-radius: 60px;
        font-size: 16px;
        line-height: 24px;
    }

    .footer-home-style .footer-main,
    body.home .footer-home-style .footer-main {
        padding: 80px 0 72px;
    }

    .footer-home-style .footer-grid,
    body.home .footer-home-style .footer-grid,
    body.post-type-archive-news .footer-home-style .footer-grid,
    body.single-news .footer-home-style .footer-grid,
    body.post-type-archive-event .footer-home-style .footer-grid,
    body.single-event .footer-home-style .footer-grid {
        display: grid;
        grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
        column-gap: 14px;
        row-gap: 66px;
        align-items: start;
    }

    .footer-home-style .footer-app,
    body.home .footer-home-style .footer-app {
        order: 0;
        grid-column: 1 / -1;
    }

    .footer-home-style .footer-about,
    body.home .footer-home-style .footer-about {
        order: 1;
        grid-column: 1 / -1;
        display: contents;
    }

    .footer-home-style .footer-logo,
    body.home .footer-home-style .footer-logo {
        order: 1;
        grid-column: 1 / -1;
    }

    .footer-home-style .footer-nav,
    body.home .footer-home-style .footer-nav {
        order: 2;
        grid-column: 1;
    }

    .footer-home-style .footer-nav ul,
    body.home .footer-home-style .footer-nav ul {
        min-height: 335px;
        gap: 12px;
        justify-content: space-between;
    }

    .footer-home-style .footer-nav a,
    body.home .footer-home-style .footer-nav a {
        font-size: 16px;
        line-height: 22px;
    }

    .footer-home-style .footer-contacts,
    body.home .footer-home-style .footer-contacts {
        order: 3;
        grid-column: 2;
        gap: 24px;
        min-width: 0;
    }

    .footer-home-style .footer-contact-item,
    body.home .footer-home-style .footer-contact-item {
        grid-template-columns: 24px minmax(0, 1fr);
        column-gap: 6px;
        row-gap: 8px;
        min-width: 0;
    }

    .footer-home-style .footer-contact-item .contact-ui-icon,
    body.home .footer-home-style .footer-contact-item .contact-ui-icon {
        width: 24px;
        height: 24px;
        flex-basis: 24px;
    }

    .footer-home-style .footer-contact-text,
    body.home .footer-home-style .footer-contact-text {
        min-width: 0;
    }

    .footer-home-style .footer-contact-label,
    body.home .footer-home-style .footer-contact-label {
        font-size: 14px;
        line-height: 19px;
    }

    .footer-home-style .footer-contact-value,
    .footer-home-style .footer-contact-value:hover,
    body.home .footer-home-style .footer-contact-value,
    body.home .footer-home-style .footer-contact-value:hover {
        font-size: 16px;
        line-height: 22px;
        letter-spacing: -0.02em;
    }

    .footer-home-style .footer-home-legal,
    body.home .footer-home-style .footer-home-legal {
        order: 4;
        grid-column: 1 / -1;
        max-width: none;
    }

    .footer-home-style .copyright-home,
    .footer-home-style .footer-home-legal a,
    body.home .footer-home-style .copyright-home,
    body.home .footer-home-style .footer-home-legal a {
        font-size: 16px;
        line-height: 22px;
    }

    .footer-home-style .footer-home-legal a[href*="privacy"],
    body.home .footer-home-style .footer-home-legal a[href*="privacy"] {
        white-space: nowrap;
    }

    .site-map {
        grid-template-columns: 1fr;
        gap: 42px;
        margin-top: 60px;
        padding-bottom: 80px;
    }

    .site-map-title {
        margin-bottom: 20px;
        font-size: 20px;
        line-height: 26px;
    }

    .site-map-list {
        gap: 10px;
    }

    .newsletter-section {
        position: relative;
        height: 464px;
        min-height: 464px;
        padding: 0;
        overflow: hidden;
        background: #0a3d62;
    }

    .newsletter-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 26px;
        padding-left: 26px;
    }

    .newsletter-bg,
    body.home .newsletter-bg,
    body.post-type-archive-news .newsletter-bg,
    body.single-news .newsletter-bg,
    body.post-type-archive-event .newsletter-bg,
    body.single-event .newsletter-bg {
        position: absolute;
        inset: 0;
        height: 464px;
        min-height: 464px;
    }

    .newsletter-bg::after,
    body.home .newsletter-bg::after,
    body.post-type-archive-news .newsletter-bg::after,
    body.single-news .newsletter-bg::after,
    body.post-type-archive-event .newsletter-bg::after,
    body.single-event .newsletter-bg::after {
        width: 180px;
        height: 420px;
        right: 0;
        top: 130px;
        bottom: auto;
        opacity: 1;
        mix-blend-mode: normal;
        background-size: contain;
        background-position: right bottom;
    }

    .newsletter-section::before {
        content: "";
        position: absolute;
        left: -171px;
        bottom: -171px;
        z-index: 1;
        width: 342px;
        height: 342px;
        border-radius: 50%;
        background: #2fb4be;
        filter: blur(133px);
        pointer-events: none;
    }

    .newsletter-content,
    body.home .newsletter-content,
    body.post-type-archive-news .newsletter-content,
    body.single-news .newsletter-content,
    body.post-type-archive-event .newsletter-content,
    body.single-event .newsletter-content {
        position: static;
        z-index: auto;
        display: block;
    }

    .newsletter-title,
    body.home .newsletter-title,
    body.post-type-archive-news .newsletter-title,
    body.single-news .newsletter-title,
    body.post-type-archive-event .newsletter-title,
    body.single-event .newsletter-title {
        position: absolute;
        z-index: 3;
        top: 68px;
        left: 26px;
        width: calc(100% - 52px);
        max-width: 348px;
        margin: 0;
        font-family: 'Montserrat', sans-serif;
        font-size: 20px;
        font-weight: 700;
        line-height: 24px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #fff;
    }

    .newsletter-description,
    body.home .newsletter-description,
    body.post-type-archive-news .newsletter-description,
    body.single-news .newsletter-description,
    body.post-type-archive-event .newsletter-description,
    body.single-event .newsletter-description {
        position: absolute;
        z-index: 3;
        top: 166px;
        left: 26px;
        width: calc(100% - 52px);
        max-width: 347px;
        margin: 0;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
        letter-spacing: -0.02em;
        color: #fff;
    }

    .newsletter-form-container,
    body.home .newsletter-form-container,
    body.post-type-archive-news .newsletter-form-container,
    body.single-news .newsletter-form-container,
    body.post-type-archive-event .newsletter-form-container,
    body.single-event .newsletter-form-container {
        position: absolute;
        z-index: 3;
        top: 211px;
        left: 26px;
        width: calc(100% - 52px);
        max-width: none;
        padding: 0;
        background: transparent;
    }

    .newsletter-form .form-control,
    .newsletter-form .btn,
    body.home .newsletter-form .form-control,
    body.home .newsletter-form .btn,
    body.post-type-archive-news .newsletter-form .form-control,
    body.post-type-archive-news .newsletter-form .btn,
    body.single-news .newsletter-form .form-control,
    body.single-news .newsletter-form .btn,
    body.post-type-archive-event .newsletter-form .form-control,
    body.post-type-archive-event .newsletter-form .btn,
    body.single-event .newsletter-form .form-control,
    body.single-event .newsletter-form .btn {
        width: 100%;
        height: 50px;
        min-height: 50px;
        max-width: none;
        border-radius: 60px;
    }

    .newsletter-form .form-control {
        padding: 13px 26px;
        font-size: 14px;
        line-height: 24px;
    }

    .newsletter-form .btn {
        margin-top: 12px;
        padding: 13px 40px;
        font-size: 14px;
        font-weight: 700;
        line-height: 24px;
    }

    .newsletter-form .newsletter-disclaimer,
    body.home .newsletter-form .newsletter-disclaimer,
    body.post-type-archive-news .newsletter-form .newsletter-disclaimer,
    body.single-news .newsletter-form .newsletter-disclaimer,
    body.post-type-archive-event .newsletter-form .newsletter-disclaimer,
    body.single-event .newsletter-form .newsletter-disclaimer {
        display: block;
        width: min(361px, 100%);
        max-width: 100%;
        margin: 16px auto 0;
        padding: 0;
        color: #d4dce5;
        font-family: 'Open Sans', sans-serif;
        font-size: 12px;
        font-weight: 400;
        line-height: 16px;
        letter-spacing: -0.02em;
        text-align: center;
    }

}

@media (max-width: 576px) {
    .breadcrumbs,
    body.post-type-archive-news .breadcrumbs,
    body.single-news .breadcrumbs,
    body.post-type-archive-event .breadcrumbs,
    body.single-event .breadcrumbs,
    body.post-type-archive-document .breadcrumbs,
    .about-management-section .breadcrumbs {
        margin: 0;
        padding-top: 12px;
        padding-bottom: 20px;
    }

    .page-title,
    .archive-list-title,
    .blog-list-title,
    .single-post-title,
    .single-event-title,
    body.post-type-archive-news .blog-list-title,
    body.post-type-archive-event .archive-list-title,
    body.post-type-archive-document .archive-list-title,
    .about-management-section .page-title {
        margin-top: 0;
		font-size: 22px;
    }
}

@media (max-width: 576px) {
    .cooperation-page-section {
        padding-bottom: 72px;
        background: #F1F5F9;
    }

    .cooperation-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .cooperation-page-content .page-title {
        margin: 0 0 32px;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #0A3D62;
    }

    .cooperation-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        width: 100%;
    }

    .cooperation-card {
        position: relative;
        display: block;
        width: 100%;
        min-height: 288px;
        height: 288px;
        padding: 30px;
        background: #fff;
    }

    .cooperation-card-icon {
        position: absolute;
        top: 30px;
        left: 30px;
        width: 60px;
        height: 60px;
        margin: 0;
        color: #2FB4BE;
    }

    .cooperation-card-title {
        position: absolute;
        top: 140px;
        left: 30px;
        width: calc(100% - 60px);
        max-width: 338px;
        margin: 0;
        font-family: 'Montserrat', sans-serif;
        font-size: 16px;
        font-weight: 600;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #2C3E50;
    }

    .cooperation-card-link {
        position: absolute;
        left: 30px;
        bottom: 30px;
        display: inline-flex;
        align-items: center;
        gap: 12px;
        margin: 0;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-weight: 700;
        line-height: 20px;
        letter-spacing: -0.02em;
        color: #2FB4BE;
    }

    .cooperation-card-link svg {
        width: 6px;
        height: 12px;
    }
}

@media (max-width: 576px) {
    .reporting-page-section {
        padding-bottom: 72px;
        background: #F1F5F9;
    }

    .reporting-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .reporting-page-content .page-title {
        margin: 0 0 32px;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #0A3D62;
    }

    .reporting-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        width: 100%;
    }

    .reporting-card {
        position: relative;
        display: block;
        width: 100%;
        min-height: 288px;
        height: 288px;
        padding: 30px;
        background: #fff;
    }

    .reporting-card.reporting-card--years.is-open {
        height: auto;
        min-height: 360px;
        padding: 30px;
    }

    .reporting-card-icon {
        position: absolute;
        top: 30px;
        left: 30px;
        width: 60px;
        height: 60px;
        margin: 0;
        color: #2FB4BE;
    }

    .reporting-card-title {
        position: absolute;
        top: 130px;
        left: 30px;
        width: calc(100% - 60px);
        max-width: 338px;
        margin: 0;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 600;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #2C3E50;
    }

    .reporting-card-link {
        position: absolute;
        left: 30px;
        bottom: 30px;
        display: inline-flex;
        align-items: center;
        gap: 12px;
        margin: 0;
        border: 0;
        padding: 0;
        background: transparent;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-weight: 700;
        line-height: 20px;
        letter-spacing: -0.02em;
        color: #2FB4BE;
    }

    .reporting-card-link svg {
        width: 6px;
        height: 12px;
    }

    .reporting-card-years-menu {
        width: 100%;
        margin: 210px 0 0;
        padding-bottom: 42px;
    }

    .reporting-card-year-link,
    .reporting-card-years-collapse {
        min-height: 34px;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-weight: 700;
        line-height: 20px;
        letter-spacing: -0.02em;
    }
}

@media (max-width: 576px) {
    .fullscreen-menu,
    .fullscreen-menu.is-open {
        min-height: 100dvh;
        background: #0A3D62;
    }

    .fullscreen-menu__inner {
        box-sizing: border-box;
        min-height: 100dvh;
        padding-top: 24px;
        padding-bottom: calc(130px + env(safe-area-inset-bottom, 0px));
        background: #0A3D62;
    }

    .fullscreen-menu__top {
        grid-template-columns: minmax(0, 194px) 24px;
        justify-content: space-between;
    }

    .fullscreen-menu__close {
        grid-column: 2;
        justify-self: end;
    }

    .fullscreen-menu__mobile-search {
        margin-top: 72px;
    }

    .fullscreen-menu__mobile-layout {
        margin-top: 50px;
    }

    .fullscreen-menu__mobile-contact-button {
        margin-top: 48px;
        margin-bottom: 0;
    }
}

@media (max-width: 380px) {
    .fullscreen-menu__top {
        grid-template-columns: minmax(0, 174px) 24px;
    }
}

@media (max-width: 576px) {
    .msp-page-section {
        background: #F1F5F9;
    }

    .msp-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .msp-support-block {
        margin-top: 60px;
        padding-bottom: 72px;
    }

    .msp-support-title {
        margin: 0 0 32px;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #0A3D62;
    }

    .msp-support-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        width: 100%;
    }

    .msp-support-card {
        position: relative;
        display: block;
        width: 100%;
        min-height: 288px;
        height: 288px;
        padding: 30px;
        background: #fff;
    }

    .msp-support-icon {
        position: absolute;
        top: 30px;
        left: 30px;
        width: 60px;
        height: 60px;
        margin: 0;
        color: #2FB4BE;
    }

    .msp-support-card-title {
        position: absolute;
        top: 130px;
        left: 30px;
        width: calc(100% - 60px);
        max-width: 338px;
        margin: 0;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 600;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
        color: #2C3E50;
    }

    .msp-support-card-link {
        position: absolute;
        left: 30px;
        bottom: 30px;
        display: inline-flex;
        align-items: center;
        gap: 12px;
        margin: 0;
        border: 0;
        padding: 0;
        background: transparent;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-weight: 700;
        line-height: 20px;
        letter-spacing: -0.02em;
        color: #2FB4BE;
    }

    .msp-support-card-link svg {
        width: 6px;
        height: 12px;
    }
}

.scroll-to-top {
    position: fixed;
    right: 30px;
    bottom: 30px;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 68px;
    height: 68px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: #2FB4BE;
    color: #FFFFFF;
    opacity: 0;
    visibility: hidden;
    transform: translateY(16px);
    transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease, background-color 0.2s ease;
    cursor: pointer;
}

.scroll-to-top.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.scroll-to-top:hover,
.scroll-to-top:focus-visible {
    background: #35c0cf;
}

.scroll-to-top span {
    display: block;
    width: 12px;
    height: 12px;
	margin-bottom: 6px;
    border-top: 3px solid currentColor;
    border-left: 3px solid currentColor;
    transform: translateY(6px) rotate(45deg);
}

@media (max-width: 576px) {
    .scroll-to-top {
        right: 20px;
        bottom: 20px;
        width: 52px;
        height: 52px;
    }
}

.cooperation-card-link {
    border: 0;
    background: transparent;
    padding: 0;
    cursor: pointer;
    font-family: var(--font-secondary);
}

.cooperation-info-modal-open {
    overflow: hidden;
}

.cooperation-info-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
}

.cooperation-info-modal.is-open {
    display: flex;
}

.cooperation-info-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.62);
}

.cooperation-info-modal__dialog {
    position: relative;
    width: min(862px, 100%);
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    padding: 60px 70px;
    background: #0A3D62;
    color: #fff;
}

.cooperation-info-modal__close {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 18px;
    height: 18px;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.cooperation-info-modal__close span {
    position: absolute;
    left: 0;
    top: 8px;
    width: 18px;
    height: 2px;
    background: #fff;
}

.cooperation-info-modal__close span:first-child {
    transform: rotate(45deg);
}

.cooperation-info-modal__close span:last-child {
    transform: rotate(-45deg);
}

.cooperation-info-modal__title {
    max-width: 640px;
    margin: 0 0 32px;
    color: #fff;
    font-family: var(--font-primary);
    font-size: 22px;
    font-weight: 700;
    line-height: 28px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.cooperation-info-modal__content {
    color: #fff;
    font-family: var(--font-secondary);
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.cooperation-info-modal__content p,
.cooperation-info-modal__content ol,
.cooperation-info-modal__content ul {
    margin: 0 0 22px;
}

.cooperation-info-modal__content p:last-child,
.cooperation-info-modal__content ol:last-child,
.cooperation-info-modal__content ul:last-child {
    margin-bottom: 0;
}

.cooperation-info-modal__content ol,
.cooperation-info-modal__content ul {
    padding-left: 24px;
}

.cooperation-info-modal__content a {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 4px;
}

@media (max-width: 576px) {
    .cooperation-info-modal {
        padding: 18px;
    }

    .cooperation-info-modal__dialog {
        max-height: calc(100vh - 36px);
        padding: 42px 28px 32px;
    }

    .cooperation-info-modal__title {
        font-size: 20px;
        line-height: 26px;
    }
}

@media (max-width: 576px) {
    .consumer-page-section {
        padding-bottom: 72px;
        background: #f1f5f9;
    }

    .consumer-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .consumer-page-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }

    .consumer-page-content .page-title {
        max-width: 370px;
        margin: 0 0 28px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .consumer-page-content .pill-tabs {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        gap: 8px;
        width: 100%;
        max-width: none;
        margin: 0 0 36px;
    }

    .consumer-page-content .pill-tab {
        flex: 0 1 auto;
        width: auto;
        min-width: 0;
        min-height: 54px;
        height: auto;
        padding: 11px 24px;
        border-radius: 60px;
        background: #fff;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
        letter-spacing: -0.02em;
        text-align: left;
        white-space: normal;
    }

    .consumer-page-content .pill-tab.is-active {
        background: #2fb4be;
        color: #fff;
    }

    .consumer-doc-panels {
        width: 100%;
    }

    .consumer-page-content .content-section-block {
        margin: 0;
    }

    .consumer-page-content .content-section-title {
        max-width: 330px;
        margin: 0 0 28px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 700;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .consumer-page-content .doc-card-grid-3 {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px 14px;
        width: 100%;
    }

    .consumer-page-content .doc-link-card {
        display: grid;
        grid-template-columns: 30px minmax(0, 1fr);
        align-items: center;
        gap: 14px;
        width: 100%;
        min-height: 92px;
        height: 92px;
        padding: 18px 20px;
        background: #fff;
        box-shadow: none;
    }

    .consumer-page-content .doc-icon {
        width: 30px;
        height: 30px;
        min-width: 30px;
    }

    .consumer-page-content .doc-icon img {
        width: 30px;
        height: 30px;
        object-fit: contain;
    }

    .consumer-page-content .doc-link-card span:last-child {
        display: -webkit-box;
        max-width: none;
        min-width: 0;
        overflow: hidden;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 10px;
        font-weight: 600;
        line-height: 12px;
        letter-spacing: -0.02em;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        text-overflow: ellipsis;
    }
}

@media (max-width: 576px) {
    .mup-page-section {
        padding-bottom: 72px;
        background: #f1f5f9;
    }

    .mup-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .mup-page-section .inner-page-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }

    .mup-page-section .page-title {
        width: auto;
        margin: 0 0 40px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .mup-page-section .split-links {
        display: grid;
        grid-template-columns: 1fr;
        gap: 54px;
        width: 100%;
    }

    .mup-page-section .content-section-title {
        max-width: 396px;
        margin: 0 0 20px;
        color: #2c3e50;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 700;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .mup-page-section .split-links ul {
        display: flex;
        flex-direction: column;
        gap: 0;
        width: 100%;
        margin: 0;
        padding: 0;
        list-style: none;
        color: #0a3d62;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        font-weight: 400;
        line-height: 36px;
        letter-spacing: -0.02em;
    }

    .mup-page-section .split-links li {
        margin: 0;
        padding: 0;
    }

    .mup-page-section .split-links a,
    .mup-page-section .mup-info-link {
        color: #0a3d62;
        font-family: inherit;
        font-size: inherit;
        font-weight: inherit;
        line-height: inherit;
        letter-spacing: inherit;
        text-decoration: underline;
        text-decoration-thickness: 1px;
        text-underline-offset: 3px;
    }

    .mup-page-section .split-links a:hover,
    .mup-page-section .split-links a:focus-visible,
    .mup-page-section .mup-info-link:hover,
    .mup-page-section .mup-info-link:focus-visible {
        color: #2fb4be;
    }
}

.search-page-content {
    max-width: 1310px;
}

.search-page-title {
    max-width: 980px;
    margin: 0 0 40px;
    color: #0a3d62;
    font-family: 'Montserrat', sans-serif;
    font-size: 54px;
    font-weight: 700;
    line-height: 62px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.search-page-form {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 68px;
    margin: 0 0 48px;
    padding: 0 24px 0 32px;
    border-radius: 60px;
    background: #fff;
}

.search-page-field {
    width: 100%;
    min-width: 0;
    border: 0;
    background: transparent;
    color: #2c3e50;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    font-weight: 400;
    line-height: 32px;
    letter-spacing: -0.02em;
    outline: 0;
}

.search-page-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border: 0;
    background: transparent;
    color: #2fb4be;
    cursor: pointer;
}

.search-results-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
    margin-bottom: 120px;
}

.search-result-card {
    display: flex;
    flex-direction: column;
    min-height: 260px;
    padding: 40px;
    border-radius: 0;
    background: #fff;
}

.search-result-card__type {
    margin: 0 0 8px;
    color: #2fb4be;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    font-weight: 700;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.search-result-card__title {
    margin: 0;
    color: #2c3e50;
    font-family: 'Open Sans', sans-serif;
    font-size: 24px;
    font-weight: 600;
    line-height: 32px;
    letter-spacing: -0.02em;
}

.search-result-card__title a {
    color: inherit;
    text-decoration: none;
}

.search-result-card__title a:hover {
    color: #2fb4be;
}

.search-result-card__excerpt {
    margin: 20px 0 0;
    color: #2c3e50;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.02em;
}

.search-page-empty {
    max-width: 640px;
    margin: 0 0 120px;
    color: #2c3e50;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    line-height: 28px;
    letter-spacing: -0.02em;
}

@media (max-width: 1200px) {
    .search-results-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .search-results-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 576px) {
    .search-page-section {
        padding-bottom: 72px;
        background: #f1f5f9;
    }

    .search-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .search-page-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }

    .search-page-title {
        margin: 0 0 24px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 46px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .search-page-form {
        width: 100%;
        min-height: 60px;
        margin: 0 0 34px;
        padding: 0 22px 0 28px;
        border-radius: 60px;
    }

    .search-page-field {
        font-size: 16px;
        line-height: 24px;
    }

    .search-page-submit {
        width: 32px;
        height: 32px;
        flex-basis: 32px;
    }

    .search-page-submit svg {
        width: 28px;
        height: 28px;
    }

    .search-results-grid {
        grid-template-columns: 1fr;
        gap: 34px;
    }

    .search-result-card {
        min-height: 240px;
        padding: 30px;
        border-radius: 28px;
    }

    .search-result-card__type {
        margin-bottom: 4px;
        font-size: 16px;
        line-height: 22px;
    }

    .search-result-card__title {
        font-size: 22px;
        line-height: 29px;
    }

    .search-result-card__excerpt {
        margin-top: 16px;
        font-size: 14px;
        line-height: 22px;
    }

    .search-page-empty {
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        line-height: 24px;
    }
}

@media (max-width: 576px) {
    .sitemap-page-section {
        padding-bottom: 72px;
        background: #f1f5f9;
    }

    .sitemap-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .sitemap-page-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }

    .sitemap-page-content .page-title {
        margin: 0 0 32px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .sitemap-page-content .site-map {
        display: grid;
        grid-template-columns: 1fr;
        gap: 36px;
        margin-top: 0;
        padding-bottom: 0;
    }

    .sitemap-page-content .site-map-title {
        margin: 0 0 16px;
        color: #2c3e50;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 700;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .sitemap-page-content .site-map-list {
        gap: 8px;
    }

    .sitemap-page-content .site-map-list a,
    .sitemap-page-content .site-map-empty {
        color: #0a3d62;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        font-weight: 400;
        line-height: 24px;
        letter-spacing: -0.02em;
    }
}

@media (max-width: 576px) {
    .consumer-market-page-section,
    .financial-results-page-section,
    .msp-page-section {
        padding-bottom: 72px;
        background: #f1f5f9;
    }

    .consumer-market-page-section > .container-fluid,
    .financial-results-page-section > .container-fluid,
    .msp-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .consumer-market-page-content,
    .financial-results-page-content,
    .msp-page-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }

    .consumer-market-page-content .page-title,
    .financial-results-page-content .page-title,
    .msp-copy .page-title,
    .msp-support-title {
        margin: 0 0 32px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .consumer-market-grid,
    .msp-support-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
        width: 100%;
    }

    .consumer-market-card,
    .msp-registry-card,
    .msp-support-card {
        position: relative;
        display: block;
        width: 100%;
        max-width: none;
        min-height: 288px;
        height: 288px;
        padding: 30px;
        background: #fff;
    }

    .consumer-market-card-icon,
    .msp-registry-icon,
    .msp-support-icon {
        position: absolute;
        top: 30px;
        left: 30px;
        display: block;
        width: 60px;
        height: 60px;
        margin: 0;
        color: #2fb4be;
    }

    .consumer-market-card-title,
    .msp-registry-title,
    .msp-support-card-title {
        position: absolute;
        top: 130px;
        left: 30px;
        right: 30px;
        width: auto;
        max-width: none;
        margin: 0;
        color: #2c3e50;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 600;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .consumer-market-card-link,
    .msp-registry-link,
    .msp-support-card-link {
        position: absolute;
        left: 30px;
        bottom: 30px;
        display: inline-flex;
        align-items: center;
        gap: 12px;
        margin: 0;
        padding: 0;
        border: 0;
        background: transparent;
        color: #2fb4be;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        font-weight: 700;
        line-height: 20px;
        letter-spacing: -0.02em;
        text-decoration: none;
    }

    .consumer-market-card-link svg,
    .msp-registry-link svg,
    .msp-support-card-link svg {
        width: 6px;
        height: 12px;
    }

    .financial-results-grid.doc-card-grid-3 {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
        width: 100%;
    }

    .financial-results-grid .doc-link-card {
        display: grid;
        grid-template-columns: 30px minmax(0, 1fr);
        align-items: center;
        gap: 14px;
        width: 100%;
        min-height: 92px;
        height: 92px;
        padding: 18px 20px;
        background: #fff;
        box-shadow: none;
    }

    .financial-results-grid .doc-icon,
    .financial-results-grid .doc-icon img {
        width: 30px;
        height: 30px;
        min-width: 30px;
        object-fit: contain;
    }

    .financial-results-grid .doc-link-card span:last-child {
        display: -webkit-box;
        max-width: none;
        min-width: 0;
        overflow: hidden;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 10px;
        font-weight: 600;
        line-height: 12px;
        letter-spacing: -0.02em;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        text-overflow: ellipsis;
    }

    .msp-hero-layout {
        display: grid;
        grid-template-columns: 1fr;
        gap: 32px;
        width: 100%;
    }

    .msp-copy .section-copy {
        max-width: none;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 14px;
        font-weight: 400;
        line-height: 24px;
        letter-spacing: -0.02em;
    }

    .msp-copy .section-copy p {
        margin: 0 0 18px;
    }

    .msp-registry-links {
        display: block;
        margin: 0;
    }

    .msp-registry-links .msp-registry-link:first-child {
        bottom: 62px;
    }

    .msp-support-block {
        margin-top: 60px;
        padding-bottom: 0;
    }

    .consumer-market-modal {
        padding: 18px;
    }

    .consumer-market-modal__dialog,
    .msp-support-modal__dialog {
        width: 100%;
        max-height: calc(100vh - 36px);
        min-height: auto;
        padding: 42px 28px 32px;
        overflow-y: auto;
    }

    .consumer-market-modal__title,
    .msp-support-modal__title {
        font-size: 20px;
        line-height: 26px;
    }

    .consumer-market-modal__text,
    .msp-support-modal__content {
        font-size: 14px;
        line-height: 22px;
    }
}

@media (max-width: 576px) {
    .support-navigator-page-section {
        padding-bottom: 72px;
        background: #f1f5f9;
    }

    .support-navigator-page-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .support-navigator-page-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }

    .support-navigator-page-content .page-title {
        margin: 0 0 32px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 22px;
        font-weight: 700;
        line-height: 28px;
        letter-spacing: -0.02em;
        text-transform: uppercase;
    }

    .support-navigator-category {
        margin: 0 0 42px;
    }

    .support-navigator-category:last-child {
        margin-bottom: 0;
    }

    .support-navigator-category .content-section-title {
        max-width: 330px;
        margin: 0 0 20px;
        color: #0a3d62;
        font-family: 'Montserrat', sans-serif;
        font-size: 18px;
        font-weight: 700;
        line-height: 22px;
        letter-spacing: -0.02em;
        text-align: left;
        text-transform: uppercase;
    }

    .support-navigator-grid.doc-card-grid-3 {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
        width: 100%;
    }

    .support-navigator-grid .doc-link-card {
        display: grid;
        grid-template-columns: 30px minmax(0, 1fr);
        align-items: center;
        gap: 14px;
        width: 100%;
        min-height: 92px;
        height: 92px;
        padding: 18px 20px;
        background: #fff;
        box-shadow: none;
    }

    .support-navigator-grid .doc-icon,
    .support-navigator-grid .doc-icon img {
        width: 30px;
        height: 30px;
        min-width: 30px;
        object-fit: contain;
    }

    .support-navigator-grid .doc-link-card span:last-child {
        display: -webkit-box;
        max-width: none;
        min-width: 0;
        overflow: hidden;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 10px;
        font-weight: 600;
        line-height: 12px;
        letter-spacing: -0.02em;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        text-overflow: ellipsis;
    }
}

@media (orientation: landscape) and (max-height: 576px) and (max-width: 1024px) {
    html,
    body {
        overflow-x: hidden;
    }

    .site-header {
        min-height: 96px;
        background: #f1f5f9;
    }

    .header-top {
        min-height: 96px;
        padding: 16px 0;
    }

    .header-top > .container-fluid,
    .container-fluid,
    body.home .news-section > .container-fluid,
    body.home .directions-section > .container-fluid,
    body.home .partners-section > .container-fluid,
    body.home .contact-form-section > .container-fluid,
    body.home .partner-strip-section > .container-fluid,
    body.home .home-contacts-map > .container-fluid,
    body.home .newsletter-section > .container-fluid,
    body.home .gosuslugi-section > .container-fluid {
        width: 100%;
        max-width: none;
        padding-right: 20px;
        padding-left: 20px;
    }

    .header-top-inner {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 24px;
        min-height: 64px;
    }

    .header-logo {
        flex: 0 0 auto;
        min-width: 0;
    }

    .site-logo.site-logo-with-text {
        width: 194px;
        height: 70px;
        gap: 13px;
    }

    .site-logo.site-logo-with-text .logo-full,
    .site-logo.site-logo-with-text .logo-full img {
        width: 50px;
        height: 70px;
    }

    .site-logo.site-logo-with-text .logo-text {
        max-width: 130px;
        gap: 6px;
    }

    .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
    }

    .logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
    }

    .header-main {
        flex: 0 0 auto;
        display: flex;
        align-items: center;
        justify-content: flex-end;
        width: auto;
        min-width: 82px;
        gap: 30px;
        margin-left: auto;
    }

    .header-utility {
        display: flex;
        width: 28px;
        max-width: 28px;
        flex: 0 0 28px;
        gap: 0;
    }

    .header-utility .header-contacts,
    .main-navigation,
    .main-navigation.active,
    .header-drawer-meta {
        display: none !important;
    }

    .header-search {
        display: block;
        width: 28px;
        max-width: 28px;
        flex: 0 0 28px;
    }

    .search-form {
        min-height: 28px;
        padding: 0;
        background: transparent;
    }

    .search-field {
        position: absolute;
        width: 1px;
        height: 1px;
        opacity: 0;
        pointer-events: none;
    }

    .search-submit,
    .search-submit svg {
        width: 28px;
        height: 28px;
    }

    .header-nav-row {
        flex: 0 0 24px;
        width: 24px;
        justify-content: flex-end;
    }

    .mobile-menu-toggle {
        display: flex;
        position: static;
        width: 24px;
        height: 20px;
        margin: 0;
    }

    .mobile-menu-toggle span:nth-child(2) {
        align-self: flex-end;
        width: 12px;
    }

    .inner-page-section,
    .documents-archive-section,
    .cooperation-page-section,
    .reporting-page-section,
    .consumer-market-page-section,
    .financial-results-page-section,
    .msp-page-section,
    .support-navigator-page-section,
    .sitemap-page-section,
    body.post-type-archive-news .news-archive-section,
    body.post-type-archive-event .events-archive-section {
        padding-top: 0;
        padding-bottom: 64px;
    }

    .hero-section {
        min-height: 360px;
        height: auto;
    }

    .hero-slide {
        min-height: 360px;
    }

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

    .hero-title {
        max-width: 520px;
        font-size: 32px;
        line-height: 38px;
    }

    .hero-actions {
        margin-top: 28px;
    }

    .breadcrumbs,
    body.post-type-archive-news .breadcrumbs,
    body.single-news .breadcrumbs,
    body.post-type-archive-event .breadcrumbs,
    body.single-event .breadcrumbs,
    body.post-type-archive-document .breadcrumbs,
    .about-management-section .breadcrumbs {
        margin: 0;
        padding-top: 12px;
        padding-bottom: 20px;
    }

    .page-title,
    .archive-list-title,
    .blog-list-title,
    .single-post-title,
    .single-event-title,
    body.post-type-archive-news .blog-list-title,
    body.post-type-archive-event .archive-list-title,
    body.post-type-archive-document .archive-list-title,
    .about-management-section .page-title,
    .search-page-title {
        margin-top: 0;
        margin-bottom: 28px;
        font-size: 28px;
        line-height: 34px;
    }

    .inner-page-content,
    .about-management-content,
    .events-archive-content,
    .news-archive-content,
    .documents-archive-content,
    .search-page-content,
    .consumer-market-page-content,
    .financial-results-page-content,
    .support-navigator-page-content,
    .msp-page-content,
    .sitemap-page-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }

    body.page-rekvizity .page-body,
    body.page-requisites .page-body,
    .page-content-section--requisites .page-body,
    body.page-rekvizity .page-body :where(p, li, td, th, div, span, a, strong, b, em),
    body.page-requisites .page-body :where(p, li, td, th, div, span, a, strong, b, em),
    .page-content-section--requisites .page-body :where(p, li, td, th, div, span, a, strong, b, em) {
        font-family: 'Open Sans', sans-serif;
        font-size: 16px !important;
        font-weight: 400;
        line-height: 24px !important;
        letter-spacing: -0.02em;
        color: #2C3E50;
    }

    .cooperation-grid,
    .reporting-grid,
    .consumer-market-grid,
    .msp-support-grid,
    .info-card-grid-3,
    .info-card-grid-4,
    .info-card-grid-2x2,
    .msp-hero-layout,
    .consumer-page-content .doc-card-grid-3,
    .support-navigator-grid.doc-card-grid-3,
    .financial-results-grid.doc-card-grid-3,
    .doc-card-grid-2,
    .doc-card-grid-3,
    .search-results-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 18px;
        width: 100%;
    }

    .news-card,
    .event-card,
    .cooperation-card,
    .reporting-card,
    .consumer-market-card,
    .msp-registry-card,
    .msp-support-card,
    .info-card,
    .search-result-card {
        width: 100%;
        max-width: none;
        min-height: 220px;
        height: auto;
        padding: 24px;
        border-radius: 0;
    }

    .doc-link-card,
    .support-navigator-grid .doc-link-card,
    .financial-results-grid .doc-link-card,
    .consumer-page-content .doc-link-card {
        width: 100%;
        min-height: 92px;
        height: auto;
        padding: 18px 20px;
    }

    .newsletter-section {
        height: auto;
        min-height: 420px;
    }

}

@media (orientation: landscape) and (max-height: 576px) and (max-width: 1024px) {
    html,
    body {
        min-width: 0;
        background: #f1f5f9;
        overflow-x: hidden;
    }

    body.fullscreen-menu-open {
        background: #0a3d62;
    }

    img,
    iframe {
        max-width: 100%;
    }

    .site-main {
        overflow: hidden;
    }

    .site-header,
    .header-top {
        min-height: 92px;
    }

    .header-top {
        padding: 12px 0;
    }

    .header-top-inner {
        min-height: 68px;
        gap: 18px;
    }

    .header-main {
        gap: 22px;
    }

    .header-utility {
        display: flex !important;
    }

    .header-search,
    .header-search .search-form {
        width: 28px;
        max-width: 28px;
    }

    .header-search .search-form {
        display: block;
        min-height: 28px;
    }

    .header-search .search-field {
        display: block;
    }

    .header-search .search-submit {
        position: static;
        padding: 0;
        transform: none;
    }

    .fullscreen-menu,
    .fullscreen-menu.is-open {
        height: 100svh;
        min-height: 100svh;
        background: #0a3d62;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .fullscreen-menu::after {
        content: "";
        position: fixed;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: -1;
        height: calc(96px + env(safe-area-inset-bottom, 0px));
        background: #0a3d62;
        pointer-events: none;
    }

    .fullscreen-menu__inner {
        display: block;
        min-height: 100svh;
        padding: 18px 20px calc(36px + env(safe-area-inset-bottom, 0px));
        background: #0a3d62;
    }

    .fullscreen-menu__top {
        display: grid;
        grid-template-columns: minmax(0, 194px) 28px;
        align-items: start;
        justify-content: space-between;
        min-height: 70px;
        gap: 20px;
    }

    .fullscreen-menu__logo {
        width: 194px;
        height: 70px;
        gap: 13px;
    }

    .fullscreen-menu__logo-icon,
    .fullscreen-menu__logo-icon img {
        width: 50px;
        height: 70px;
    }

    .fullscreen-menu__logo-text {
        max-width: 130px;
        padding-top: 0;
    }

    .fullscreen-menu__logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
    }

    .fullscreen-menu__logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
    }

    .fullscreen-menu__top-search {
        display: none !important;
    }

    .fullscreen-menu__columns,
    .fullscreen-menu__contacts {
        display: none;
    }

    .fullscreen-menu__close {
        position: relative;
        top: 8px;
        right: 0;
        grid-column: 2;
        justify-self: end;
        width: 28px;
        height: 28px;
    }

    .fullscreen-menu__close span {
        left: 2px;
        width: 28px;
    }

    .fullscreen-menu__mobile-search {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        max-width: none;
        height: 52px;
        min-height: 52px;
        margin: 20px 0 0;
        padding: 0 22px;
        overflow: hidden;
        border: 0;
        border-radius: 50px;
        background: #ffffff;
        box-shadow: none;
    }

    .fullscreen-menu__mobile-search-field {
        width: 100%;
        height: 100%;
        min-width: 0;
        padding: 0;
        border: 0;
        outline: 0;
        background: transparent;
        color: #2c3e50;
        font-family: 'Open Sans', sans-serif;
        font-size: 16px;
        line-height: 22px;
    }

    .fullscreen-menu__mobile-search-submit {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        min-width: 28px;
        padding: 0;
        border: 0;
        background: transparent;
        box-shadow: none;
        cursor: pointer;
    }

    .fullscreen-menu__mobile-search-submit svg {
        width: 28px;
        height: 28px;
    }

    .fullscreen-menu__mobile-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(280px, 0.9fr);
        align-items: start;
        gap: 32px;
        margin: 24px 0 0;
    }

    .fullscreen-menu__mobile-nav {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }

    .fullscreen-menu__mobile-nav a {
        color: #ffffff;
        font-size: 16px;
        line-height: 22px;
        text-decoration: none;
    }

    .fullscreen-menu__mobile-meta {
        gap: 10px;
        min-width: 0;
        align-self: start;
        padding-top: 0;
    }

    .fullscreen-menu__mobile-contact {
        gap: 8px;
        min-width: 0;
        align-items: center;
        font-size: 16px;
        line-height: 22px;
    }

    .fullscreen-menu__mobile-contact svg,
    .fullscreen-menu__mobile-contact img {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }

    .fullscreen-menu__mobile-contact a,
    .fullscreen-menu__mobile-contact span {
        min-width: 0;
        white-space: normal;
        overflow-wrap: anywhere;
        line-height: 22px;
    }

    .fullscreen-menu__mobile-contact-button {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        max-width: none;
        min-height: 52px;
        margin: 24px 0 0;
        padding: 14px 32px;
        border: 0;
        border-radius: 60px;
        background: #2fb4be;
        color: #ffffff;
        font-family: 'Open Sans', sans-serif;
        font-weight: 700;
        font-size: 16px;
        line-height: 22px;
        text-align: center;
        box-shadow: none;
    }

    .breadcrumbs {
        font-size: 14px;
        line-height: 20px;
    }

    .single-news-layout,
    .single-event-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(230px, 0.42fr);
        gap: 28px;
        align-items: start;
    }

    .single-news-sidebar,
    .single-event-sidebar {
        position: static;
        width: auto;
        max-width: none;
        margin: 0;
    }

    .single-news-sidebar .sidebar-title,
    .single-event-sidebar .sidebar-title {
        margin-top: 0;
    }

    .consumer-market-card,
    .msp-support-card,
    .cooperation-card,
    .reporting-card,
    .msp-registry-card {
        display: flex;
        flex-direction: column;
        gap: 20px;
        min-height: 240px;
        padding: 24px;
    }

    .consumer-market-card-icon,
    .msp-support-icon,
    .cooperation-card-icon,
    .reporting-card-icon,
    .msp-registry-icon {
        position: static;
        width: 60px;
        height: 60px;
        margin: 0;
    }

    .consumer-market-card-title,
    .msp-support-card-title,
    .cooperation-card-title,
    .reporting-card-title,
    .msp-registry-title {
        position: static;
        width: auto;
        max-width: none;
        margin: 0;
        font-size: 18px;
        line-height: 22px;
    }

    .consumer-market-card-link,
    .msp-support-card-link,
    .cooperation-card-link,
    .reporting-card-link,
    .msp-registry-link {
        position: static;
        margin-top: auto;
        font-size: 16px;
        line-height: 20px;
    }

    .consumer-market-card-link svg,
    .msp-support-card-link svg,
    .cooperation-card-link svg,
    .reporting-card-link svg,
    .msp-registry-link svg {
        flex: 0 0 auto;
    }

    .info-card {
        min-height: 302px;
        height: auto;
        padding: 30px;
    }

    .info-card-number {
        top: 30px;
        left: 30px;
        width: 60px;
        height: 60px;
        font-size: 18px;
        line-height: 28px;
    }

    .info-card h3 {
        top: 128px;
        left: 30px;
        max-width: calc(100% - 60px);
        font-size: 18px;
        line-height: 24px;
    }

    .info-card a {
        top: auto;
        bottom: 30px;
        left: 30px;
        gap: 12px;
        font-size: 16px;
        line-height: 20px;
    }

    .info-card a::after {
        width: 6px;
        height: 12px;
    }

    .info-card-art {
        top: 51px;
        right: -59px;
        width: 200px;
        height: 200px;
    }

    body.home .home-contacts-map,
    .home-contacts-map {
        min-height: 520px;
        padding: 48px 0;
    }

    body.home .home-contacts-map-embed iframe,
    .home-contacts-map-embed iframe {
        height: 520px;
    }

    body.home .home-contacts-card,
    .home-contacts-card {
        width: min(420px, calc(100vw - 40px));
        height: auto;
        min-height: 0;
        padding: 34px;
        transform: none;
    }

    body.home .home-contacts-card .content-section-title,
    .home-contacts-card .content-section-title {
        margin-bottom: 26px;
        font-size: 28px;
        line-height: 34px;
    }

    body.home .home-contacts-list,
    .home-contacts-list {
        gap: 12px;
        margin-bottom: 30px;
        font-size: 16px;
        line-height: 24px;
    }

    body.home .home-contacts-item,
    .home-contacts-item {
        font-size: 16px;
        line-height: 24px;
    }

    body.home .home-contacts-card .btn,
    .home-contacts-card .btn {
        width: 100%;
        min-width: 0;
        min-height: 54px;
    }

    .reporting-card-years-menu {
        margin: 8px 0 0;
        padding-bottom: 0;
    }

    .doc-link-card,
    .support-navigator-grid .doc-link-card,
    .financial-results-grid .doc-link-card,
    .consumer-page-content .doc-link-card {
        display: flex;
        align-items: center;
        gap: 18px;
    }

    .doc-link-card .doc-icon,
    .doc-icon,
    .support-navigator-grid .doc-icon,
    .support-navigator-grid .doc-icon img {
        width: 30px;
        height: 30px;
        flex: 0 0 30px;
    }

    .doc-link-card span:last-child,
    .support-navigator-grid .doc-link-card span:last-child,
    .financial-results-grid .doc-link-card span:last-child {
        display: -webkit-box;
        min-width: 0;
        overflow: hidden;
        font-size: 12px;
        line-height: 15px;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        text-overflow: ellipsis;
    }

    .search-page-form {
        width: 100%;
        max-width: none;
        margin-bottom: 30px;
    }

    .search-result-card {
        min-height: 170px;
    }

    .newsletter-section {
        min-height: 360px;
        padding: 44px 0;
    }

    .newsletter-section > .container-fluid {
        padding-right: 20px;
        padding-left: 20px;
    }

    .newsletter-bg,
    body.home .newsletter-bg,
    body.post-type-archive-news .newsletter-bg,
    body.single-news .newsletter-bg,
    body.post-type-archive-event .newsletter-bg,
    body.single-event .newsletter-bg {
        min-height: 360px;
        padding: 44px 0;
    }

    .newsletter-bg::after,
    body.home .newsletter-bg::after,
    body.post-type-archive-news .newsletter-bg::after,
    body.single-news .newsletter-bg::after,
    body.post-type-archive-event .newsletter-bg::after,
    body.single-event .newsletter-bg::after {
        right: -110px;
        bottom: -62px;
        width: 260px;
        height: 360px;
        background-size: contain;
        background-position: right bottom;
    }

    .newsletter-content {
        display: block;
        max-width: 520px;
    }

    .newsletter-title,
    body.home .newsletter-title,
    body.post-type-archive-news .newsletter-title,
    body.single-news .newsletter-title,
    body.post-type-archive-event .newsletter-title,
    body.single-event .newsletter-title {
        max-width: 520px;
        margin-bottom: 22px;
        font-size: 22px;
        line-height: 28px;
    }

    .newsletter-description,
    body.home .newsletter-description,
    body.post-type-archive-news .newsletter-description,
    body.single-news .newsletter-description,
    body.post-type-archive-event .newsletter-description,
    body.single-event .newsletter-description {
        max-width: 520px;
        margin-bottom: 16px;
        font-size: 16px;
        line-height: 24px;
    }

    .newsletter-form-container,
    body.home .newsletter-form-container,
    body.post-type-archive-news .newsletter-form-container,
    body.single-news .newsletter-form-container,
    body.post-type-archive-event .newsletter-form-container,
    body.single-event .newsletter-form-container {
        width: 100%;
        max-width: 520px;
        margin: 0;
    }

    .newsletter-form .form-control,
    .newsletter-form .btn,
    body.home .newsletter-form .form-control,
    body.home .newsletter-form .btn,
    body.post-type-archive-news .newsletter-form .form-control,
    body.post-type-archive-news .newsletter-form .btn,
    body.single-news .newsletter-form .form-control,
    body.single-news .newsletter-form .btn,
    body.post-type-archive-event .newsletter-form .form-control,
    body.post-type-archive-event .newsletter-form .btn,
    body.single-event .newsletter-form .form-control,
    body.single-event .newsletter-form .btn {
        width: 100%;
        max-width: 520px;
        height: 52px;
        min-height: 52px;
    }

    .newsletter-form .newsletter-disclaimer,
    body.home .newsletter-form .newsletter-disclaimer,
    body.post-type-archive-news .newsletter-form .newsletter-disclaimer,
    body.single-news .newsletter-form .newsletter-disclaimer,
    body.post-type-archive-event .newsletter-form .newsletter-disclaimer,
    body.single-event .newsletter-form .newsletter-disclaimer {
        max-width: 520px;
        margin-top: 12px;
        font-size: 12px;
        line-height: 16px;
    }

    .footer-home-style .footer-main,
    body.home .footer-home-style .footer-main {
        padding: 48px 0 40px;
    }

    .footer-home-style .footer-grid,
    body.home .footer-home-style .footer-grid,
    body.post-type-archive-news .footer-home-style .footer-grid,
    body.single-news .footer-home-style .footer-grid,
    body.post-type-archive-event .footer-home-style .footer-grid,
    body.single-event .footer-home-style .footer-grid {
        display: grid;
        grid-template-columns: minmax(180px, 0.85fr) minmax(130px, 0.55fr) minmax(220px, 1fr);
        align-items: start;
        column-gap: 28px;
        row-gap: 28px;
        min-height: 0;
    }

    .footer-home-style .footer-about,
    body.home .footer-home-style .footer-about {
        display: flex;
        grid-column: 1;
        min-height: 0;
        gap: 24px;
    }

    .footer-home-style .footer-logo,
    body.home .footer-home-style .footer-logo {
        grid-column: auto;
    }

    .footer-home-style .footer-home-logo {
        width: 194px;
        gap: 13px;
    }

    .footer-home-style .footer-home-logo .logo-icon,
    .footer-home-style .footer-home-logo .logo-icon img {
        width: 50px;
        height: 70px;
        flex-basis: 50px;
    }

    .footer-home-style .footer-home-logo .logo-subtitle {
        width: 110px;
        font-size: 9.13px;
        line-height: 1.2;
    }

    .footer-home-style .footer-home-logo .logo-title {
        width: 130px;
        font-size: 10.93px;
        line-height: 13px;
    }

    .footer-home-style .footer-nav,
    body.home .footer-home-style .footer-nav {
        grid-column: 2;
        min-height: 0;
    }

    .footer-home-style .footer-nav ul,
    body.home .footer-home-style .footer-nav ul {
        min-height: 0;
        height: auto;
        gap: 12px;
        justify-content: flex-start;
    }

    .footer-home-style .footer-nav a,
    body.home .footer-home-style .footer-nav a {
        font-size: 14px;
        line-height: 20px;
    }

    .footer-home-style .footer-contacts,
    body.home .footer-home-style .footer-contacts {
        grid-column: 3;
        min-height: 0;
        gap: 14px;
    }

    .footer-home-style .footer-contact-item,
    body.home .footer-home-style .footer-contact-item {
        grid-template-columns: 22px minmax(0, 1fr);
        column-gap: 8px;
        row-gap: 4px;
    }

    .footer-home-style .footer-contact-item .contact-ui-icon,
    body.home .footer-home-style .footer-contact-item .contact-ui-icon {
        width: 22px;
        height: 22px;
        flex-basis: 22px;
    }

    .footer-home-style .footer-contact-label,
    body.home .footer-home-style .footer-contact-label {
        font-size: 13px;
        line-height: 18px;
    }

    .footer-home-style .footer-contact-value,
    .footer-home-style .footer-contact-value:hover,
    body.home .footer-home-style .footer-contact-value,
    body.home .footer-home-style .footer-contact-value:hover {
        font-size: 15px;
        line-height: 21px;
        overflow-wrap: anywhere;
    }

    .footer-home-style .footer-home-legal,
    body.home .footer-home-style .footer-home-legal {
        grid-column: 1 / -1;
        max-width: none;
        gap: 2px;
    }

    .footer-home-style .copyright-home,
    .footer-home-style .footer-home-legal a,
    body.home .footer-home-style .copyright-home,
    body.home .footer-home-style .footer-home-legal a {
        font-size: 14px;
        line-height: 20px;
    }

    .footer-home-style .footer-home-legal a[href*="privacy"],
    body.home .footer-home-style .footer-home-legal a[href*="privacy"] {
        white-space: normal;
    }

    .footer-home-style .footer-app,
    body.home .footer-home-style .footer-app {
        display: none;
    }
}

@media (orientation: landscape) and (max-height: 430px) and (max-width: 740px) {
    .fullscreen-menu__mobile-search {
        margin-top: 14px;
    }

    .fullscreen-menu__mobile-layout {
        grid-template-columns: minmax(0, 1fr) minmax(250px, 0.9fr);
        gap: 24px;
        margin-top: 18px;
    }

    .fullscreen-menu__mobile-nav {
        gap: 8px;
    }

    .fullscreen-menu__mobile-meta {
        gap: 8px;
    }

    .fullscreen-menu__mobile-contact-button {
        max-width: none;
        min-height: 48px;
        margin-top: 18px;
        border-radius: 60px;
    }

    .footer-home-style .footer-grid,
    body.home .footer-home-style .footer-grid,
    body.post-type-archive-news .footer-home-style .footer-grid,
    body.single-news .footer-home-style .footer-grid,
    body.post-type-archive-event .footer-home-style .footer-grid,
    body.single-event .footer-home-style .footer-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }

    .footer-home-style .footer-about,
    .footer-home-style .footer-nav,
    .footer-home-style .footer-contacts,
    body.home .footer-home-style .footer-about,
    body.home .footer-home-style .footer-nav,
    body.home .footer-home-style .footer-contacts {
        grid-column: auto;
    }

    .footer-home-style .footer-contacts,
    body.home .footer-home-style .footer-contacts {
        gap: 10px;
    }
}

@media (orientation: landscape) and (max-height: 700px) and (max-width: 1366px) {
    body.post-type-archive-news .blog-list-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 18px;
        width: 100%;
    }

    body.post-type-archive-news .blog-list-grid .news-card {
        display: grid;
        grid-template-columns: minmax(150px, 42%) minmax(0, 1fr);
        width: 100%;
        min-height: 260px;
        height: 260px;
        max-height: 260px;
        overflow: hidden;
    }

    body.post-type-archive-news .blog-list-grid .news-card-image,
    body.post-type-archive-news .blog-list-grid .news-card-image a,
    body.post-type-archive-news .blog-list-grid .news-image,
    body.post-type-archive-news .blog-list-grid .news-image-placeholder {
        width: 100%;
        height: 260px;
    }

    body.post-type-archive-news .blog-list-grid .news-card-body {
        height: 260px;
        padding: 28px 24px;
    }

    body.post-type-archive-news .news-card-title {
        font-size: 16px;
        line-height: 24px;
		width: 200px;
    }
}
