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

    html,
    body,
    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    p,
    ul,
    ol,
    li,
    figure,
    figcaption,
    blockquote,
    dl,
    dd {
        margin: 0;
        padding: 0;
    }

    ul[role='list'],
    ol[role='list'] {
        list-style: none;
    }

    html:focus-within {
        scroll-behavior: smooth;
    }

    body {
        min-height: 100vh;
        text-rendering: optimizeLegibility;
        -webkit-font-smoothing: antialiased;
    }

    a {
        text-decoration: none;
        color: inherit;
    }

    img,
    picture {
        max-width: 100%;
        display: block;
    }

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



    body {
        font-family: "Montserrat", sans-serif;
        background: #F4F7FB;
        color: #1A3150;
        line-height: 1.5;
    }

    .container {
        width: min(1200px, 92%);
        margin-inline: auto;
    }

    .header {
        padding: 16px 0;
    }

    .header__row {
        display: grid;
        grid-template-columns: auto 1fr auto;
        align-items: center;
        gap: 20px;
    }

    .logo img {
        height: 80px;
        display: block;
    }

    .nav {
        display: flex;
        justify-content: space-evenly;
        gap: 32px;
        font-weight: 500;
        color: #1A3150;
        font-size: 20px;
    }

    .nav a:hover {
        color: #24354F;
    }

    .header__cta {
        padding: 12px 18px;
        border-radius: 999px;
        background: #1A3150;
        color: #fff;
        font-weight: 700;
        box-shadow: 0px 0px 20px #00CFFF, 0px 0px 20px #66FFFF;
    }

    .header__burger {
        width: 40px;
        height: 40px;
        border: 0;
        background: transparent;
        display: none;
        position: relative;
    }

    .header__burger span {
        display: block;
        height: 2px;
        background: #1A3150;
        margin: 7px 0;
        width: 24px;
        margin-left: auto;
    }

    .mnav {
        position: fixed;
        inset: 0;
        z-index: 999;
        display: none;
    }

    .mnav[aria-hidden="false"] {
        display: block;
    }

    .mnav__backdrop {
        position: absolute;
        inset: 0;
        background: rgba(13, 23, 40, .55);
    }

    .mnav__panel {
        position: absolute;
        top: 0;
        right: 0;
        height: 100%;
        width: min(86vw, 360px);
        background: #FFFFFF;
        box-shadow: -20px 0 50px rgba(0, 0, 0, .2);
        padding: 20px;
        display: flex;
        flex-direction: column;
        gap: 14px;
    }

    .mnav__panel a {
        color: #1A3150;
        font-weight: 700;
        padding: 12px 6px;
    }

    .mnav__cta {
        margin-top: 10px;
        display: inline-flex;
        justify-content: center;
    }

    .mnav__close {
        align-self: flex-end;
        border: 0;
        background: transparent;
        font-size: 22px;
        line-height: 1;
    }

    @media (max-width: 1024px) {
        .nav {
            display: none;
        }

        .header__burger {
            display: block;
        }

        .header__row {
            grid-template-columns: auto 1fr auto 40px;
        }

        .header__cta {
            justify-self: center;
        }
    }

    @media (max-width: 420px) {
        .header__cta {
            padding: 10px 14px;
            font-size: 14px;
            box-shadow: 0 8px 22px rgba(10, 37, 64, .26), 0 0 0 8px rgba(0, 255, 240, .12);

        }

        .logo img {
            height: 80px;
        }
    }

    @media (max-width: 525px) {
        .header__cta {
            display: none;
        }

        .header__row {
            grid-template-columns: 1fr auto;
        }
    }

    .hero {
        padding: 56px 0 40px;
    }

    .hero__grid {
        display: grid;
        grid-template-columns: 1.4fr .6fr;
        align-items: center;
        gap: 40px;
    }

    .eyebrow {
        font-weight: 300;
        color: #1A3150;
        letter-spacing: .02em;
        font-size: 16px;
        margin-bottom: 18px;
    }

    .hero__title {
        font-weight: 600;
        font-size: clamp(28px, 4vw, 48px);
        line-height: 1.15;
        letter-spacing: 0.2px;
        color: #1A3150;
        margin-bottom: 18px;
    }

    .hero__lead {
        font-size: 22px;
        color: #1A3150;
        max-width: 52ch;
        margin-bottom: 28px;
    }

    .btn-primary {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 18px 26px;
        border-radius: 999px;
        background: #1A3150;
        color: #EAF4FF !important;
        font-weight: 700;
        border: 0;
        box-shadow: 0px 0px 20px #00CFFF, 0px 0px 20px #66FFFF;
        transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
        margin-top:31px;
        margin-bottom:31px;
    }

    .btn-primary:hover {
        transform: translateY(-1px);
        box-shadow: 0px 0px 20px #00b6df, 0px 0px 20px #51cbcb;
    }

    .hero__visual img {
        width: 100%;
    }

    .chip {
        background: #dfe9ff;
        border-radius: 28px;
        overflow: hidden;
        position: relative;
        box-shadow: 0 10px 24px rgba(21, 58, 115, 0.15);
        min-height: 140px;

        background-image: radial-gradient(120% 120% at 100% 0%, #0EC8FF 0%, #274A86 55%, #0F1F3A 100%);
    }

    .chip--tall {
        grid-row: span 2;
        min-height: 300px;
    }

    .chip--wide {
        min-height: 160px;
    }

    .chip--small {
        min-height: 140px;
    }


    .chip img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }


    @media (max-width: 980px) {
        .hero__grid {
            grid-template-columns: 1fr;
        }

        .hero__visual {
            order: -1;
        }

        .nav {
            display: none;
        }

        .header__cta {
            padding: 12px 18px;
        }
    }

    .about {
        padding: clamp(48px, 8vw, 96px) 0;
    }

    .about__grid {
        display: grid;
        grid-template-columns: 1.4fr .8fr;
        align-items: center;
        gap: clamp(24px, 5vw, 30px);
    }

    .about__heading {
        font-weight: 700;
        font-size: clamp(24px, 3vw, 36px);
        color: #1A3150;
        margin-bottom: 26px;
        letter-spacing: .2px;
    }

    .about__title {
        font-weight: 500;
        font-size: 30px;
        line-height: 1.25;
        color: #1A3150;
        margin-bottom: 24px;
    }

    .about__subtitle {
        font-weight: 500;
        color: #1A3150;
        font-size: 22px;
        margin-bottom: 14px;
    }

    .about__bullets {
        list-style: none;
        margin: 0 0 14px 0;
        display: grid;
        gap: 10px;
        color: #1A3150;
        font-size: 22px;
    }

    .about__bullets li {
        position: relative;
        padding-left: 20px;
    }

    .about__bullets li::before {
        content: "—";
        position: absolute;
        left: 0;
        top: 0;
        color: #394f70;
    }

    .about__note {
        margin: 14px 0 25px;
        font-size: 22px;
        font-weight: 400;
        color: #1A3150;
    }

    .about__text {
        color: #1A3150;
        font-size: 22px;
    }

    .about__visual {
        border-radius: 28px;
        overflow: hidden;
        box-shadow: 0 14px 36px rgba(21, 58, 115, 0.16);
    }

    .about__visual img {
        width: 100%;
        display: block;
    }

    @media (max-width: 980px) {
        .about__grid {
            grid-template-columns: 1fr;
        }

        .about__visual {
            order: -1;
        }
    }

    .stats {
        background: white;
        padding: clamp(40px, 7vw, 88px) 0;
    }

    .stats__heading {
        font-weight: 700;
        font-size: clamp(24px, 3vw, 36px);
        color: #1A3150;
        margin-bottom: clamp(20px, 3vw, 32px);
    }

    .stats__grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 28px;
    }

    .stat-card {
        display: grid;
        grid-template-columns: 1fr auto;
        align-items: center;
        gap: 18px;
        background: #F1F5FA;
        border-radius: 26px;
        padding: clamp(18px, 3vw, 28px);
        box-shadow: 0 8px 18px rgba(21, 58, 115, .06);
    }

    .stat-card__title {
        font-weight: 500;
        font-size: clamp(20px, 2.4vw, 28px);
        color: #1A3150;
        letter-spacing: .2px;
        margin-bottom: 6px;
    }

    .stat-card__desc {
        color: #1A3150;
        font-size: 22px;
    }

    .stat-card__icon {
        width: 72px;
        height: 72px;
        display: grid;
        place-items: center;
    }

    .stats__cta {
        display: grid;
        place-items: center;
        margin-top: clamp(24px, 5vw, 42px);
    }

    .btn-glow {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 18px 36px;
        border-radius: 999px;
        background: #1A3150;
        color: #FFFFFF;
        font-weight: 700;
        letter-spacing: .3px;
        box-shadow: 0px 0px 20px #00CFFF, 0px 0px 20px #66FFFF;
        transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
    }

    .btn-glow:hover {
        transform: translateY(-1px);
        background: #223853;
        box-shadow: 0px 0px 20px #00b6df, 0px 0px 20px #51cbcb;
    }

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

        .stat-card__icon {
            width: 60px;
            height: 60px;
        }
    }

    .reviews {
        padding: clamp(44px, 7vw, 96px) 0;
    }

    .reviews__heading {
        font-weight: 700;
        font-size: clamp(24px, 3vw, 36px);
        color: #1A3150;
        margin-bottom: clamp(20px, 3vw, 28px);
    }

    .reviews__slider {
        overflow: visible;
    }

    .review-card {
        background: #FFFFFF;
        border: 1px solid #E6EDF6;
        border-radius: 24px;
        box-shadow: 0 12px 28px rgba(21, 58, 115, .08);
        overflow: hidden;
        height: 100%;
        display: grid;
        grid-template-rows: auto 1fr;
    }

    .review-card__media img {
        width: 100%;
        object-fit: cover;
        display: block;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }

    .review-card__body {
        padding: 18px 18px 20px;
    }

    .review-card__name {
        font-weight: 500;
        font-size: 30px;
        color: #1A3150;
        margin-bottom: 12px;
    }

    .review-card__meta {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px;
        margin-bottom: 14px;
    }

    .pill {
        position: relative;
        display: grid;
        align-items: center;
        grid-template-columns: 1fr auto;
        gap: 10px;
        padding: 12px 14px;
        background: #F1F5FA;
        border-radius: 14px;
        border: 1px solid #E6EDF6;
    }

    .pill__label {
        color: #1A3150;
        font-size: 14px;
        font-weight: 300;
    }

    .pill__label strong {
        font-weight: 700;
    }

    .pill__value {
        color: #1A3150;
        font-weight: 700;
        white-space: nowrap;
    }

    .pill__ic {
        width: 22px;
        height: 22px;
        display: grid;
        place-items: center;
    }

    .review-card__date {
        display: inline-grid;
        grid-auto-flow: column;
        align-items: center;
        gap: 10px;
        background: #F1F5FA;
        border-radius: 12px;
        border: 1px solid #E6EDF6;
        padding: 10px 12px;
        margin-bottom: 12px;
        width: fit-content;
    }

    .date__label {
        color: #1A3150;
        font-size: 14px;
        font-weight: 300;
    }

    .date__label strong {
        font-weight: 700;
    }

    .date__value {
        color: #1A3150;
        font-weight: 700;
    }

    .date__ic {
        width: 20px;
        height: 20px;
        display: grid;
        place-items: center;
    }

    .review-card__text {
        font-size: 16px;
        color: #1A3150;
    }

    .reviews__nav {
        display: grid;
        grid-template-columns: auto 1fr auto;
        align-items: center;
        gap: 16px;
        margin-top: 18px;
    }

    .reviews__btn {
        width: 80px;
        height: 80px;
        border-radius: 999px;
        border: 0;
        background: none;
        display: none;
        place-items: center;
        cursor: pointer;
    }

    .reviews__btn:hover {
        transform: translateY(-1px);
    }

    .reviews__pagination {
        position: static !important;
        text-align: center;
    }

    .reviews__pagination .swiper-pagination-bullet {
        width: 8px;
        height: 8px;
        opacity: .4;
        background: #1A3150;
    }

    .reviews__pagination .swiper-pagination-bullet-active {
        opacity: 1;
        width: 22px;
        border-radius: 999px;
    }

    .reviews__cta {
        display: grid;
        place-items: center;
        margin-top: clamp(26px, 5vw, 40px);
    }

    @media (max-width: 1200px) {}

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


    }

    .reviews__slider {
        overflow: hidden;
    }

    .certs {
        padding: clamp(44px, 7vw, 96px) 0;
    }

    .certs__heading {
        font-weight: 700;
        font-size: clamp(24px, 3vw, 36px);
        color: #1A3150;
        margin-bottom: clamp(20px, 3vw, 28px);
    }

    .certs__grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 26px;
    }

    .cert {
        display: grid;
        grid-template-columns: auto 1fr;
        gap: 20px;
        align-items: center;
        background: #F1F5FA;
        border: 1px solid #E6EDF6;
        border-radius: 22px;
        padding: 18px;
        box-shadow: 0 10px 22px rgba(21, 58, 115, .06);
    }

    .cert__img {
        width: clamp(120px, 24vw, 210px);
        border-radius: 16px;
        overflow: hidden;
        background: #fff;
        box-shadow: inset 0 0 0 1px #E6EDF6;
    }

    .cert__img img {
        width: 100%;
    }

    .cert__title {
        font-weight: 500;
        font-size: clamp(18px, 2.1vw, 22px);
        color: #1A3150;
        margin-bottom: 10px;
    }

    .cert__desc {
        color: #1A3150;
        font-size: 16px;
    }

    .certs__cta {
        display: grid;
        place-items: center;
        margin-top: clamp(26px, 5vw, 40px);
    }

    @media (max-width: 1024px) {
        .certs__grid {
            grid-template-columns: 1fr;
        }
    }

    @media (max-width: 640px) {
        .cert {
            grid-template-columns: 1fr;
            align-items: start;
        }

        .cert__img {
            width: 100%;
        }
    }

    .cases {
        background: white;
        padding: clamp(44px, 7vw, 96px) 0;
    }

    .cases__heading {
        font-weight: 700;
        font-size: clamp(24px, 3vw, 36px);
        color: #1A3150;
        margin-bottom: clamp(20px, 3vw, 28px);
    }

    .cases__grid {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 26px;
    }

    .case-card {
        position: relative;
        height: 260px;
        border-radius: 22px;
        overflow: hidden;
        box-shadow: 0 18px 36px rgba(21, 58, 115, .16);
        background: #000;
    }

    .case-card__img {
        width: 100%;
        display: block;
        transform: scale(1.02);
        transition: transform .35s ease;
    }

    .case-card__overlay {
        position: absolute;
        inset: 0;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
        padding: 22px;
        color: #fff;

    }

    .case-card__title {
        font-weight: 600;
        font-size: clamp(18px, 2.1vw, 22px);
        margin-bottom: 15px;
        line-height: 1.25;
        text-shadow: 0 2px 8px rgba(0, 0, 0, .35);
    }

    .case-card__text {
        font-size: 16px;
        color: rgba(255, 255, 255, .92);
        text-shadow: 0 1px 6px rgba(0, 0, 0, .35);
    }

    .case-card:hover .case-card__img {
        transform: scale(1.04);
    }

    .cases__cta {
        display: grid;
        place-items: center;
        margin-top: clamp(26px, 5vw, 40px);
    }

    @media (max-width: 1200px) {
        .cases__grid {
            grid-template-columns: 1fr 1fr;
        }

        .case-card {
            height: 240px;
        }
    }

    @media (max-width: 720px) {
        .cases__grid {
            grid-template-columns: 1fr;
        }

        .case-card {
            height: 220px;
        }

        .reviews__btn {

            display: flex;
        }
    }

    @media (max-width: 767px) {

        .reviews__btn {

            display: flex;
        }
    }

    .how {
        background: white;
        padding: clamp(44px, 7vw, 96px) 0;
    }

    .how__heading {
        font-weight: 700;
        font-size: clamp(24px, 3vw, 36px);
        color: #1A3150;
        margin-bottom: clamp(20px, 3vw, 28px);
    }

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

    .how-card {
        background: #F1F5FA;
        border: 1px solid #E6EDF6;
        border-radius: 24px;
        padding: 22px 22px 24px;
        box-shadow: 0 12px 26px rgba(21, 58, 115, .08);
        display: grid;
        align-content: start;
        gap: 12px;
        min-height: 260px;
    }

    .how-card__icon {
        width: 64px;
        height: 64px;
        border-radius: 999px;
        background: #FFFFFF;
        box-shadow: 0 10px 20px rgba(21, 58, 115, .08), inset 0 0 0 1px #E6EDF6;
        display: grid;
        place-items: center;
        margin-bottom: 6px;
    }

    .how-card__icon img {
        width: 50px;
        height: 50px;
    }

    .how-card__title {
        font-weight: 500;
        font-size: 22px;
        color: #1A3150;
    }

    .how-card__text {
        font-size: 16px;
        color: #1A3150;
    }

    .how__cta {
        display: grid;
        place-items: center;
        margin-top: clamp(26px, 5vw, 40px);
    }

    @media (max-width: 1100px) {
        .how__grid {
            grid-template-columns: repeat(2, 1fr);
        }
    }

    @media (max-width: 640px) {
        .how__grid {
            grid-template-columns: 1fr;
        }
    }

    .status {
        padding: clamp(44px, 8vw, 108px) 0;
    }

    .status__grid {
        display: grid;
        grid-template-columns: 1.3fr .7fr;
        gap: clamp(28px, 6vw, 56px);
        align-items: center;
    }

    .status__title {
        font-weight: 700;
        font-size: clamp(28px, 4.2vw, 36px);
        line-height: 1.15;
        color: #1A3150;
        letter-spacing: .2px;
        margin-bottom: clamp(16px, 2.2vw, 22px);
    }

    .status__item {
        display: grid;
        grid-template-columns: 40px 1fr;
        gap: 14px;
        align-items: start;
        margin-top: 18px;
    }

    .status__icon {
        width: 40px;
        height: 40px;
        display: grid;
        place-items: center;
        color: #1A3150;
    }

    .status__text {
        color: #1A3150;
        font-size: 16px;
    }

    .status__visual {
        border-radius: 6px;
        overflow: hidden;
        box-shadow: 0 16px 34px rgba(21, 58, 115, .14);
    }

    .status__visual img {
        width: 100%;
        display: block;
    }

    @media (max-width: 1100px) {
        .status__grid {
            grid-template-columns: 1fr;
        }

        .status__visual {
            order: -1;
        }

        .status__title {
            max-width: none;
        }
    }

    .compare {
        padding: clamp(44px, 7vw, 96px) 0;
    }

    .compare__heading {
        font-weight: 700;
        font-size: clamp(24px, 3vw, 36px);
        color: #1A3150;
        line-height: 1.2;
        max-width: 400px;
    }

    .compare__wrap {
        background: #fff0;
        border-radius: 16px;
        overflow: hidden;
    }

    .compare__table {
        width: 100%;
        border-collapse: collapse;
        font-size: 18px;
        color: #1A3150;
    }

    .compare__table thead th {
        text-align: left;
        font-size: 22px;
        font-weight: 500;
        color: #2c3f5b;
        padding: 16px 18px;
        border-bottom: 2px solid #cfd9e6;
    }

    .compare__table thead th:nth-child(2),
    .compare__table thead th:nth-child(3) {
        text-align: center;
    }

    .compare__table tbody td {
        padding: 22px 18px;
        border-bottom: 1px solid #cfd9e6;
        font-size: 22px;
    }

    .col--feature {
        width: 52%;
    }

    .col--brand {
        width: 24%;
    }

    .tc {
        text-align: center;
    }

    .ic {
        display: inline-grid;
        place-items: center;
        width: 50px;
        height: 50px;
        border-radius: 999px;
        box-shadow: 0 4px 10px rgba(0, 0, 0, .08);
    }

    .ic--ok {
        background-color: #52E218;
        -webkit-mask: url('../img/check_ok.svg') center/60% no-repeat;
        mask: url('../img/check_ok.svg') center/60% no-repeat;
    }

    .ic--no {
        background: #DA2C2C;
        -webkit-mask: url('../img/check_no.svg') center/60% no-repeat;
        mask: url('../img/check_no.svg') center/60% no-repeat;
    }

    .btn-glow {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 18px 36px;
        border-radius: 999px;
        background: #1A3150;
        color: #fff;
        font-weight: 700;
        letter-spacing: .3px;
        box-shadow: 0px 0px 20px #00CFFF, 0px 0px 20px #66FFFF;
        transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
    }

    .btn-glow:hover {
        transform: translateY(-1px);
        background: #223853;
        box-shadow: 0px 0px 20px #00b6df, 0px 0px 20px #51cbcb;
    }

    .compare__cta {
        display: grid;
        place-items: center;
        margin-top: clamp(26px, 5vw, 40px);
    }

    @media (max-width: 900px) {
        .compare__table {
            font-size: 16px;
        }

        .col--feature {
            width: 56%;
        }
    }

    @media (max-width: 680px) {

        .compare__table tbody td {
            font-size: 16px;
            padding: 18px 6px;
        }

        .compare__table thead th:nth-child(2),
        .compare__table thead th:nth-child(3) {
            font-size: 14px;
        }

        .ic {
            width: 28px;
            height: 28px;
        }
    }


    .contact {
        padding: clamp(44px, 8vw, 108px) 0;
    }

    .contact__grid {
        display: grid;
        grid-template-columns: 1.2fr .8fr;
        gap: clamp(28px, 6vw, 56px);
        align-items: start;
    }

    .contact__title {
        font-weight: 700;
        font-size: clamp(28px, 4.4vw, 36px);
        line-height: 1.15;
        color: #1A3150;
        margin-bottom: 12px;
        letter-spacing: .2px;
    }

    #contactModalTitle {
        max-width: 600px;
        margin: 0 auto;
        margin-bottom: 20px;
    }

    .contact__lead {
        color: #4a5e7e;
        margin-bottom: 18px;
    }

    .contact__lead-modal {
        font-size: 16px;
    }

    .contact__form {
        margin-top: 8px;
    }

    .form-row {
        margin-bottom: 14px;
    }

    .form-control {
        width: 100%;
        padding: 14px 18px;
        border-radius: 999px;
        border: 1.5px solid #cfd9e6;
        background: #fff;
        color: #1A3150;
        outline: none;
        transition: border-color .2s ease, box-shadow .2s ease;
    }

    .form-control::placeholder {
        color: #7688a5;
    }

    .form-control:focus {
        border-color: #7fa8ff;
        box-shadow: 0 0 0 4px rgba(127, 168, 255, .15);
    }

    .phone-group {
        position: relative;
        display: flex;
        align-items: center;
    }

    .phone-prefix {
        flex: 0 0 auto;
        display: inline-grid;
        grid-auto-flow: column;
        align-items: center;
        gap: 8px;
        padding-left: 12px;
        color: #1A3150;
        pointer-events: none;
        position: absolute;
        left: 0;
    }


    .code {
        font-weight: 700;
        opacity: .9;
    }

    .form-control--phone {
        padding-left: 72px;
    }

    .check {
        display: inline-grid;
        grid-auto-flow: column;
        gap: 10px;
        align-items: center;
        color: #1A3150;
        margin: 8px 0 18px;
        user-select: none;
    }

    .check input {
        width: 18px;
        height: 18px;
        accent-color: #0B65FF;
    }

    .contact__submit {
        width: min(560px, 100%);
        justify-content: center;
        margin: 8px 0 12px;
    }

    .contact__policy {
        color: #6a7c98;
        font-size: 14px;
    }

    .contact__policy a {
        color: #2b4e87;
        text-decoration: underline;
    }

    .contact__visual {
        border-radius: 6px;
        overflow: hidden;
        box-shadow: 0 16px 34px rgba(21, 58, 115, .14);
    }

    .contact__visual img {
        width: 100%;
        display: block;
    }

    .footer {
        padding: clamp(24px, 4vw, 40px) 0 36px;
    }

    .footer__row {
        display: grid;
        grid-template-columns: auto 1fr auto;
        gap: 16px 20px;
        align-items: flex-end;
    }

    .footer__copy {
        color: #4d5f7c;
        text-align: center;
    }

    .footer__link {
        color: #2b4e87;
        text-decoration: underline;
        justify-self: end;
    }

    @media (max-width: 1100px) {
        .contact__grid {
            grid-template-columns: 1fr;
        }

        .contact__visual {
            order: 2;
        }
    }

    @media (max-width: 640px) {
        .footer__row {
            grid-template-columns: 1fr;
            text-align: center;
        }

        .footer__link {
            justify-self: center;
        }
    }

    .modal {
        position: fixed;
        inset: 0;
        z-index: 1000;
        display: none;
    }

    .modal[aria-hidden="false"] {
        display: block;
    }

    .modal__backdrop {
        position: absolute;
        inset: 0;
        background: rgba(13, 23, 40, .6);
        backdrop-filter: blur(2px);
    }

    .modal__dialog {
        position: relative;
        z-index: 1;
        width: min(840px, 92%);
        margin: 6vh auto;
        background: #FFFFFF;
        border-radius: 26px;
        box-shadow:
            0 30px 80px rgba(8, 24, 54, .45),
            0 0 0 6px rgba(0, 255, 255, .06),
            0 0 30px 8px rgba(0, 200, 255, .25);
        border: 2px solid #6de3ff;
    }

    .modal__content {
        padding: clamp(20px, 4vw, 36px);
    }

    .modal__close {
        position: absolute;
        right: 16px;
        top: 16px;
        width: 44px;
        height: 44px;
        border: 0;
        background: transparent;
        cursor: pointer;
    }

    .contact__title {
        font-weight: 700;
        color: #1A3150;
        font-size: clamp(22px, 3vw, 32px);
        line-height: 1.25;
        text-align: center;
        margin-bottom: 10px;
    }

    .contact__lead {
        text-align: center;
        color: #4a5e7e;
        margin-bottom: 16px;
    }

    .contact__form {
        width: min(560px, 100%);
        margin: 0 auto;
    }

    .form-row {
        margin-bottom: 14px;
    }

    .form-control {
        width: 100%;
        padding: 14px 18px;
        border-radius: 999px;
        border: 1.5px solid #cfd9e6;
        background: #fff;
        color: #1A3150;
        outline: none;
        transition: border-color .2s, box-shadow .2s;
    }

    .form-control::placeholder {
        color: #7688a5;
    }

    .form-control:focus {
        border-color: #7fa8ff;
        box-shadow: 0 0 0 4px rgba(127, 168, 255, .15);
    }

    .phone-group {
        position: relative;
        display: flex;
        align-items: center;
    }

    .phone-prefix {
        position: absolute;
        left: 10px;
        display: inline-grid;
        grid-auto-flow: column;
        gap: 8px;
        align-items: center;
        pointer-events: none;
    }


    .code {
        font-weight: 700;
        color: #1A3150;
    }

    .form-control--phone {
        padding-left: 72px;
    }

    .check {
        display: inline-grid;
        grid-auto-flow: column;
        gap: 10px;
        align-items: center;
        color: #1A3150;
        margin: 8px 0 18px;
    }

    .check input {
        width: 18px;
        height: 18px;
        accent-color: #0B65FF;
    }

    .modal__submit {
        width: 100%;
        justify-content: center;
        margin-bottom: 12px;
    }

    .contact__policy {
        text-align: center;
        color: #6a7c98;
        font-size: 14px;
    }

    .contact__policy a {
        color: #2b4e87;
        text-decoration: underline;
    }

    @media (max-width: 520px) {
        .modal__dialog {
            margin: 3vh auto;
        }


    }



    main .policy {
        background: F6F7FA;
        padding: 80px 0 72px;
        color: #333333;
    }




    .policy-block {
        margin-top: 56px;
    }

    .policy-block>.title {
        margin: 0 0 18px;
        font-weight: 800;
        font-size: 34px;
        line-height: 1.2;
        letter-spacing: .01em;
        color: #333333;
        text-transform: inherit;
    }

    .policy h2 {
        font-size: 40px;
        text-transform: uppercase;
    }

    .policy-block p {
        margin: 10px 0;
        font-size: 24px;
        font-weight: 300;
        line-height: 1.75;
        color: #333333;
    }

    .policy a {
        color: #0A66C2;
        text-underline-offset: 2px;
    }

    .policy a:hover {
        color: #084a8e
    }

    .policy-block p strong {
        color: #333333;
        font-weight: 800;
    }

    @media (max-width: 1024px) {
        .policy>.container-fluid>.title:first-of-type {
            font-size: 40px
        }

        .policy-block>.title {
            font-size: 30px
        }
    }

    @media (max-width: 680px) {
        .policy {
            padding: 24px 0 56px
        }

        .policy>.container-fluid>.title:first-of-type {
            font-size: 32px
        }

        .policy-block {
            margin-top: 40px
        }

        .policy-block>.title {
            font-size: 26px
        }

        .policy-block p {
            font-size: 16px;
            line-height: 1.7
        }
    }

    .thanks {
        padding: clamp(40px, 10vw, 120px) 0;
        background: #F4F7FB;
    }

    .thanks__card {
        width: min(980px, 94%);
        margin: 0 auto;
        background: #FFFFFF;
        border-radius: 26px;
        padding: clamp(28px, 6vw, 100px) clamp(22px, 5vw, 50px);
        border: 1px solid #D7E8EF;
        box-shadow:
            0 22px 48px rgba(10, 37, 64, .10),
            0 0 0 14px rgba(0, 255, 240, .12),
            0 0 40px rgba(0, 239, 255, .28);
    }

    .thanks__title {
        font-weight: 500;
        color: #1A3150;
        text-align: center;
        letter-spacing: .2px;
        font-size: clamp(22px, 3.6vw, 38px);
        line-height: 1.25;
        margin-bottom: clamp(10px, 2vw, 16px);
    }

    .thanks__lead {
        text-align: center;
        color: #1A3150;
        font-size: clamp(16px, 2vw, 26px);
        margin-bottom: clamp(18px, 3vw, 28px);
    }

    .thanks__subtitle {
        text-align: center;
        color: #1C2C45;
        font-weight: 500;
        letter-spacing: .2px;
        line-height: 1.25;
        font-size: clamp(22px, 3.6vw, 38px);
    }

    .thanks__subtitle span {
        display: block;
        margin-top: 6px;
        font-size: inherit;
    }

    @media (max-width: 520px) {
        .thanks__card {
            border-radius: 22px;
        }
    }

    .certs__slider {
        display: none;
    }
 

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

    .certs .swiper {
        overflow: hidden;
    }


    .certs__pagination {
        position: static;
        margin-top: 14px;
        text-align: center;
    }

    .certs__pagination .swiper-pagination-bullet {
        width: 8px;
        height: 8px;
        background: #1D2A3B;
        opacity: .4;
    }

    .certs__pagination .swiper-pagination-bullet-active {
        opacity: 1;
        width: 22px;
        border-radius: 999px;
    }


    @media (max-width: 900px) {
        .certs__grid {
            display: none !important;
        }

        .certs__slider {
            display: block;
        }
    }


    .certs__nav {
        display: none;
        grid-template-columns: auto 1fr auto;
        align-items: center;
        gap: 14px;
        margin-top: 12px;
    }

    .certs__btn {
        width: 80px;
        height: 80px;
        border: 0;
        border-radius: 999px;
        background: none; 
        display: grid;
        place-items: center;
        cursor: pointer;
    }

    .certs__btn svg {
        display: block
    }

    @media (max-width:900px) {
        .certs__nav {
            display: grid;
        }
    }