.swiper-project-container {
    position: relative;
}

.swiper-project {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
    display: block;
    height: 850px;
}

.swiper-thumb-project {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
    display: block;
}

.swiper-project-container .swiper-slide {
    background-size: cover;
    background-position: center center;
}

.swiper-project-container .swiper-slide .project-slide-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(240deg, transparent, rgb(22 32 25 / 60%));
}

.swiper-project .swiper-slide .item {
    position: absolute;
    color: #fff;
    width: min(400px, calc(100vw - 900px - max(15px, calc((100vw - 1200px) / 2 + 15px))));
    left: max(15px, calc((100vw - 1200px) / 2 + 15px));
    bottom: 65px;
}

.swiper-project .swiper-slide .item .title {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.swiper-project .swiper-slide .item .address {
    margin-bottom: 10px;
    display: flex;
    align-items: flex-start;
}

.swiper-project .swiper-slide .item .address svg {
    margin-right: 8px;
    width: 17px;
    min-width: 17px;
    margin-top: 1px;
}

.swiper-project .swiper-slide .item .describe {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 26px;
}

.swiper-project .swiper-slide .item .link-button {
    --width: 174px;
}

.swiper-thumb-project {
    position: absolute;
    bottom: 65px;
    height: 202px;
    width: 800px;
    right: 0;
    padding: 2px;
}

.swiper-thumb-project .swiper-slide {
    align-items: flex-end;
    display: flex;
    padding: 24px;
    color: #fff;
    font-weight: bold;
}

.swiper-thumb-project .swiper-slide::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: linear-gradient(0, rgb(22 32 25 / 80%), transparent 50%);
    z-index: -1;
}

.swiper-thumb-project .swiper-slide .title {
    font-size: 22px;
    font-family: "Playfair Display", serif;
}

.swiper-thumb-project .swiper-slide-active {
    outline: 2px solid #fff;
}

.swiper-thumb-project-navigation {
    position: absolute;
    width: 40px;
    z-index: 1;
    bottom: 40px;
    right: 816px;
    height: 200px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.swiper-thumb-project-navigation .swiper-nav {
    width: 40px;
    height: 41px;
    cursor: pointer;
}

.swiper-thumb-project-navigation .swiper-nav svg rect {
    transition: fill 0.3s ease;
}

.swiper-thumb-project-navigation .swiper-nav:hover svg rect {
    fill: #054444;
}

.swiper-thumb-project-navigation .swiper-nav svg path {
    transition: stroke 0.3s ease;
}

.swiper-thumb-project-navigation .swiper-nav:hover svg path {
    stroke: #fff;
}

.swiper-project .heading {
    position: absolute;
    z-index: 2;
    top: 88px;
    left: max(15px, calc((100vw - 1200px) / 2 + 15px));
}

.swiper-project .heading .heading-background {
    transform: translateX(-80px);
}