:root {
    --brand-dark: #2E435A;
    --brand-orange: #FD7E14;
    --brand-orange-border: #F8B883;
    --brand-blue: #0664BD;
    --white-button-border: #80ABD9;
    --body: #2E435A;
    --muted: rgba(46, 67, 90, .68);
    --line: rgba(46, 67, 90, .28);
}

* {
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    margin: 0;
    font-family: 'Poppins', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    font-weight: 300;
    color: var(--body);
    background: #f7f9fb;
    overflow-x: hidden
}

.page-glow {
    position: relative;
    isolation: isolate
}

.page-glow:before, .page-glow:after {
    content: "";
    position: absolute;
    z-index: -1;
    border-radius: 999px;
    filter: blur(45px);
    pointer-events: none
}

.page-glow:before {
    width: 48rem;
    height: 48rem;
    left: -14rem;
    top: 12rem;
    background: rgba(20, 112, 192, .14)
}

.page-glow:after {
    width: 42rem;
    height: 42rem;
    right: -12rem;
    top: 4rem;
    background: rgba(253, 126, 20, .13)
}

.soft-bg {
    position: relative;
    background: linear-gradient(110deg, #f7f9fb 0%, #f3f8fc 45%, #fbf1e9 100%)
}

.soft-bg:after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 18% 38%, rgba(30, 115, 190, .16), transparent 24rem), radial-gradient(circle at 72% 12%, rgba(253, 126, 20, .12), transparent 24rem), radial-gradient(circle at 78% 70%, rgba(30, 115, 190, .14), transparent 28rem);
    pointer-events: none
}

.soft-bg > * {
    position: relative;
    z-index: 1
}

h1, h2, h3, h4 {
    color: var(--brand-dark);
    font-weight: 600;
    letter-spacing: .012em
}

h1 {
    font-size: clamp(2.3rem, 3.1vw, 4rem);
    line-height: 1
}

h2 {
    font-size: clamp(2rem, 2.9vw, 3.5rem);
    line-height: 1
}

p {
    line-height: 1.35;
    color: var(--body);
    font-weight: 300
}

.muted-word {
    color: rgba(46, 67, 90, .15)
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255, 255, 255, .9);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(46, 67, 90, .12)
}

.navbar {
    min-height: 76px
}

.navbar-brand img {
    width: 228px;
    max-width: 55vw;
    height: auto
}

.nav-link {
    font-weight: 400;
    color: var(--brand-dark);
    font-size: .95rem
}

.nav-link:hover, .nav-link.active {
    color: var(--brand-orange)
}

.navbar-toggler {
    border: 0
}

.btn {
    border-radius: 8px;
    font-weight: 400;
    padding: .8rem 1.35rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    transition: .18s ease;
    border: 1px solid transparent;
    text-decoration: none
}

.btn-orange {
    background: var(--brand-orange);
    color: #fff;
    border-color: var(--brand-orange-border);
    box-shadow: 0 14px 28px rgba(253, 126, 20, .18)
}

.btn-orange:hover {
    background: #e97210;
    color: #fff;
    transform: translateY(-1px);
    border-color: var(--brand-orange-border)
}

.btn-white {
    background: #fff;
    color: var(--brand-dark);
    border-color: var(--white-button-border);
    box-shadow: 0 12px 25px rgba(0, 0, 0, .06)
}

.btn-white:hover {
    color: var(--brand-dark);
    border-color: var(--white-button-border);
    transform: translateY(-1px)
}

.btn-orange,
.btn-white {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
}

.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
    margin-right: .5rem;
}

.btn-icon svg {
    width: 1rem;
    height: 1rem;
}

.section-rule, .section-line {
    width: 235px;
    height: 1px;
    background: var(--line);
    margin-bottom: 2rem
}

.section-line.light {
    background: rgba(255, 255, 255, .45)
}

.hero-section {
    padding: 88px 0 58px
}

.hero-copy p {
    font-size: clamp(1.08rem, 2vw, 1.35rem);
    max-width: 610px;
    margin: 1.35rem 0 1.65rem
}

.hero-visual {
    width: 100%;
    max-width: 820px;
    display: block;
    margin-left: auto;
    filter: drop-shadow(0 20px 35px rgba(46, 67, 90, .13))
}

.stat-card h3{
    font-size: 2rem;
    margin-top: 1rem !important;
}
.stat-card {
    --mouse-x: 50%;
    --mouse-y: 50%;

    min-height: 112px;
    position: relative;
    overflow: hidden;
    background: #fff;
    border: 1px solid rgba(46, 67, 90, .08);
    border-radius: 10px;
    padding: 1.7rem 2rem;
    box-shadow: 0 14px 30px rgba(46, 67, 90, .10);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.stat-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(
            circle at var(--mouse-x) var(--mouse-y),
            rgba(128, 171, 217, .42),
            rgba(255, 255, 255, 0) 45%
    );
    opacity: 0;
    transition: opacity .25s ease;
    pointer-events: none;
}

.stat-card:hover {
    border-color: #80ABD9;
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(46, 67, 90, .16);
}

.stat-card:hover::before {
    opacity: 1;
}

.stat-card h3,
.stat-card p {
    position: relative;
    z-index: 1;
    margin: 0;
}

.products-section {
    padding: 64px 0 92px;
}

.product-block {
    min-height: 360px;
}

.product-background {
    min-height: 450px;
    background-color: var(--brand-blue);
    border-radius: 18px;
    box-shadow: 0 22px 45px rgba(46, 67, 90, .14);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.product-background-image {
    width: min(82%, 520px);
    height: auto;
    object-fit: contain;
    transform: translateY(1rem);
}

.product-background:after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, .03), rgba(255, 255, 255, .06));
    pointer-events: none
}

.product-copy p {
    font-size: 1.15rem;
    max-width: 470px
}

.comparison-section {
    background: #fff;
    padding: 76px 0 78px
}

.comparison-section h2 {
    text-align: center
}

.comparison-table-wrap {
    max-width: 780px;
    margin: 38px auto 0;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 16px 36px rgba(46, 67, 90, .1);
    border: 1px solid rgba(46, 67, 90, .08)
}

.comparison-table {
    margin: 0;
    background: #fff;
    font-size: .9rem;
    color: var(--body)
}

.comparison-table th {
    background: #f1f3f7;
    color: var(--brand-dark);
    font-weight: 600;
    text-align: center;
    border-color: #e9edf2
}

.comparison-table th:nth-child(2) {
    background: var(--brand-dark);
    color: #fff
}

.comparison-table td.check{
    color: var(--brand-orange)
}

.comparison-table td {
    border-color: #edf0f4;
    padding: .66rem .9rem;
    font-weight: 300
}

.comparison-table td:first-child {
    font-weight: 300;
    color: var(--brand-dark);
    width: 58%
}

.check, .dash {
    text-align: center;
    font-size: 1.25rem;
    font-weight: 600
}

.check {
    color: var(--brand-orange)
}

.dash {
    color: #9ba4ad
}

.partners-section {
    padding: 80px 0 88px
}

.partners-carousel {
    position: relative;
    overflow: hidden;
    margin-top: 38px;
    mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent)
}

.partners-track {
    display: flex;
    align-items: center;
    gap: 54px;
    width: max-content;
    animation: scrollPartners 28s linear infinite
}

.partner-logo {
    width: 150px;
    height: 72px;
    object-fit: contain;
    opacity: .52;
    filter: grayscale(1);
    mix-blend-mode: multiply
}

.partners-track:hover {
    animation-play-state: paused
}

@keyframes scrollPartners {
    from {
        transform: translateX(0)
    }
    to {
        transform: translateX(-50%)
    }
}

.cta-band {
    background: var(--brand-blue);
    padding: 58px 0;
    color: #fff
}

.cta-band h2, .cta-band p {
    color: #fff
}

.cta-band p {
    font-size: 1.1rem;
    max-width: 520px
}

.cta-band .btn-white {
    color: var(--brand-dark)
}

.footer {
    padding: 86px 0 38px;
    background: linear-gradient(110deg, #f7f9fb 0%, #f5f8fb 45%, #fbefe5 100%);
    position: relative;
    overflow: hidden
}

.footer:before {
    content: "";
    position: absolute;
    width: 36rem;
    height: 36rem;
    border-radius: 50%;
    right: 8%;
    top: 8%;
    background: rgba(253, 126, 20, .14);
    filter: blur(45px)
}

.footer .container {
    position: relative
}

.footer-logo {
    width: 320px;
    max-width: 100%;
    height: auto
}

.footer h4 {
    font-size: 1.65rem;
    color: #333;
    margin-bottom: .7rem
}

.footer p, .footer a {
    font-size: .96rem;
    color: var(--body);
    text-decoration: none;
    margin-bottom: .25rem;
    font-weight: 300
}

.footer-links {
    display: flex;
    gap: 56px;
    margin-top: 70px
}

.copyright {
    color: var(--body);
    text-align: right;
    margin-top: 56px;
    font-size: .9rem;
    font-weight: 300
}

.about-hero {
    padding: 72px 0 68px
}

.team-card {
    text-align: center
}

.team-photo {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 10px;
    box-shadow: 0 16px 30px rgba(46, 67, 90, .16)
}

.team-card h3 {
    font-size: 1.05rem;
    margin-top: 1rem
}

.mission {
    padding: 56px 0
}

.locations {
    padding: 68px 0 82px
}


.location-map {
    width: 100%;
    aspect-ratio: 16 / 7;
    border: 0;
    border-radius: 12px;
    box-shadow: 0 16px 30px rgba(46, 67, 90, .12);
    filter: grayscale(1) contrast(.95) brightness(1.05);
}

.location-title {
    text-align: center;
    margin-top: 1.25rem;
    font-size: 1.2rem;
    font-weight: 400
}

@media (max-width: 991.98px) {
    .hero-section {
        padding: 54px 0 46px
    }

    .hero-visual {
        margin: 1.5rem auto 0
    }

    .stats-row {
        margin-top: 36px
    }

    .products-section {
        padding: 44px 0 68px
    }

    .product-block {
        min-height: auto
    }

    .product-background {
        min-height: 260px
    }

    .section-rule, .section-line {
        width: 170px;
        margin-bottom: 1.25rem
    }

    .cta-band {
        text-align: center
    }

    .cta-band .section-line {
        margin-left: auto;
        margin-right: auto
    }

    .footer-links {
        margin-top: 36px
    }

    .copyright {
        text-align: left;
        margin-top: 28px
    }
}

@media (max-width: 575.98px) {
    .navbar-brand img {
        width: 190px
    }

    .btn {
        width: auto;
        padding: .72rem 1rem
    }

    .stat-card {
        padding: 1.25rem
    }

    .comparison-table {
        font-size: .72rem
    }

    .comparison-table td {
        padding: .55rem .5rem
    }

    .partners-track {
        gap: 34px
    }

    .partner-logo {
        width: 120px;
        height: 58px
    }

    .footer-links {
        gap: 28px;
        flex-wrap: wrap
    }

    .hero-section {
        padding-top: 38px
    }

    .product-background {
        min-height: 210px
    }
}
