/*
Theme Name: BĐS
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.0
*/

/*************** ADD CUSTOM CSS HERE.   ***************/

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

* {
    margin: 0;
    padding: 0;
    font: inherit;
}

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

input,
select,
textarea {
    background-color: transparent;
    outline: none;
}

button {
    cursor: pointer;
    background-color: transparent;
    outline: none;
    border: 0;
}

body {
    min-height: 100vh;
    font-weight: 400;
}

@keyframes shine {
    0% {
        left: -100px;
    }

    60% {
        left: 100%;
    }

    to {
        left: 100%;
    }
}

.section-title {
    justify-content: center;
}

.section-title b {
    display: none;
}

/* 
.wrapper {
    margin-top: 1rem;
    width: 90%;
    max-width: 1536px;
    margin-inline: auto;
    height: 100px;
    position: relative;
    overflow: hidden;
    mask-image: linear-gradient(to right,
            rgba(0, 0, 0, 0),
            rgba(0, 0, 0, 1) 20%,
            rgba(0, 0, 0, 1) 80%,
            rgba(0, 0, 0, 0));
}

@keyframes scrollLeft {
    to {
        left: -200px;
    }
}

@keyframes scrollRight {
    to {
        right: -200px;
    }
}

.itemLeft,
.itemRight {
    width: 160px;
    height: 80px;
    border-radius: 6px;
    position: absolute;
    animation-timing-function: linear;
    animation-duration: 30s;
    animation-iteration-count: infinite;
    display: flex;

}

.itemLeft img,
.itemRight img {
    width: auto;
    height: 100%;
    max-height: 80px;
    object-fit: contain;
    margin: auto;
    display: block;
    user-select: none;
    pointer-events: none;

}


.itemLeft {
    left: max(calc(160px * var(--count)), 100%);
    animation-name: scrollLeft;
}

.itemRight {
    right: max(calc(160px * var(--count)), calc(100% + 160px));
    animation-name: scrollRight;
}

.wrapper:hover .itemLeft,
.wrapper:hover .itemRight {
    animation-play-state: paused;
} */
.slider-auto-wrapper {
    overflow: hidden;
    width: 90%;
    max-width: 1536px;
    margin: 1rem auto;
    height: 100px;
    position: relative;
    mask-image: linear-gradient(to right,
            rgba(0, 0, 0, 0),
            rgba(0, 0, 0, 1) 10%,
            rgba(0, 0, 0, 1) 90%,
            rgba(0, 0, 0, 0));
}

.slider-auto-track {
    display: flex;
    width: max-content;
    animation: scrollLeft 30s linear infinite;
    will-change: transform;
}

.slider-auto-track.reverse {
    animation-name: scrollRight;
}

.slider-auto-wrapper:hover .slider-auto-track {
    animation-play-state: paused;
}

@keyframes scrollLeft {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

@keyframes scrollRight {
    0% {
        transform: translateX(-50%);
    }

    100% {
        transform: translateX(0);
    }
}

.item_slide_auto {
    flex: 0 0 auto;
    width: 160px;
    height: 80px;
    margin-right: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.item_slide_auto img {
    max-height: 80%;
    width: auto;
    object-fit: contain;
    pointer-events: none;
    user-select: none;
}



.fw-100 {
    font-weight: 100 !important;
}

.fw-200 {
    font-weight: 200 !important;
}

.fw-300 {
    font-weight: 300 !important;
}

.fw-400 {
    font-weight: 400 !important;
}

.fw-500 h3 {
    font-weight: 500 !important;
}

.fw-600 {
    font-weight: 600 !important;
}

.fw-700 {
    font-weight: 700 !important;
}

.fw-800 {
    font-weight: 800 !important;
}

.fw-900 {
    font-weight: 900 !important;
}

@media only screen and (max-width: 48em) {
    /*************** ADD MOBILE ONLY CSS HERE  ***************/


}

/* root cũ */
/* :root {
    --primary-color: #c59d3f;
    --hover-link-color: #a4770d;
    --primary-color-second: #e2c687;
    --gold-color: #c59d3f;
    --secondary-color: #f0f0f0;
    --bg-color-2: #f4f4f4;
    --text-color: #333;
    --banner-bg-color: #e0e0e0;
    --button-hover-color1: #95762e;
    --button-hover-color: #0d1526;
    --color-base: #212A37;

    --background-linear-gradient: linear-gradient(90deg, #a3741f, #c59d3f, #f0d68c);

} */
.ux-box,
.ux-card {
    transition: none !important;
    animation: none !important;
}

:root {
    --primary-color: #00A89D;
    --primary-dark-color: #00494a;
    --hover-link-color: #008F85;
    --primary-color-second: #008F85;
    --gold-color: #00A89D;
    --secondary-color: #f0f0f0;
    --bg-color-2: #F5FBFA;
    --text-color: #333;
    --banner-bg-color: #e0e0e0;
    --button-hover-color1: #008F85;
    --button-hover-color: #00494a;
    --color-base: #212A37;
    --gold-color: #c59d3f;

    /* --background-linear-gradient: linear-gradient(90deg, #a3741f, #c59d3f, #f0d68c); */
    --background-linear-gradient: linear-gradient(90deg, #00A89D, #008F85, #F5FBFA);

}

.section-title-container {
    margin-bottom: 30px;
}

.header-main {
    transition: all 0.3s ease-in-out;
}

#loadMoreBtn,
.loadMoreBtn {
    margin: 0 auto;
    /* width: fit-content;
    color: var(--primary-color);
    border-radius: 3px;
    font-weight: 500;
    font-size: 14px;
    cursor: pointer;
    background: white;
    transition: background-color 0.3s ease-in-out;
    border: 1px solid var(--primary-color); */
    line-height: 1.4;
}

.nav-spacing-large>li {
    margin-right: 24px;
}

.nav-spacing-large>li:last-child {
    margin-right: 0;
}

.nav-spacing-large>li a {
    font-size: 18px;
}

#loadMoreBtn:hover {
    /* background-color: var(--hover-link-color);
    color: white; */
}

/* Spinner  */
/* HTML: <div class="loader"></div> */
.loader_custom {
    width: 40px;
    aspect-ratio: 1;
    display: grid;
    border: 3px solid #0000;
    border-radius: 50%;
    border-color: var(--primary-color) #0000;
    animation: l16 1s infinite linear;
}

.loader_custom::before,
.loader_custom::after {
    content: "";
    grid-area: 1/1;
    margin: 2px;
    border: inherit;
    border-radius: 50%;
}

.loader_custom::before {
    border-color: var(--banner-bg-color) #0000;
    animation: inherit;
    animation-duration: .5s;
    animation-direction: reverse;
}

.loader_custom::after {
    margin: 8px;
}

@keyframes l16 {
    100% {
        transform: rotate(1turn)
    }
}

/* .box-text-banner {
    position: relative;
} */
.header:not(.transparent) .header-nav-main.nav>li>a {
    color: #fff !important;
}

.header:not(.transparent) .header-nav-main.nav>li>a:hover,
.header:not(.transparent) .header-nav-main.nav>li.active>a,
.header:not(.transparent) .header-nav-main.nav>li.current>a,
.header:not(.transparent) .header-nav-main.nav>li>a.active,
.header:not(.transparent) .header-nav-main.nav>li>a.current {
    /* color: var(--hover-link-color) !important; */
    opacity: 0.8 !important;
}

.header-nav-main.nav-line-bottom>li>a:before,
.header-nav-main.nav-line-grow>li>a:before,
.header-nav-main.nav-line>li>a:before,
.header-nav-main.nav-box>li>a:hover,
.header-nav-main.nav-box>li.active>a,
.header-nav-main.nav-pills>li>a:hover,
.header-nav-main.nav-pills>li.active>a {
    color: #FFF !important;
    background-color: var(--hover-link-color) !important;
}

.header-nav {
    justify-content: center !important;
}

#logo {
    height: 100%;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

#logo a {
    display: flex;
    align-items: center;
    justify-content: center;
}

#logo img,
#logo svg {
    height: 100%;
    max-height: 100px !important;
    width: auto;
    border-radius: 0 0 3px 3px;
    transition: all 0.2s ease-in-out;

}

#logo a img:hover {
    /* display: none !important; */
    transform: translateY(-2px) scale(1.1);
    /* --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); */
}

#logo img[src$=".svg"] {
    width: 300px;
    height: auto;
    display: inline-block;
}

.header-wrapper.stuck {
    max-height: 90px !important;
}

.header.show-on-scroll,
.stuck .header-main {
    max-height: 60px !important;
    background: var(--primary-color);
}



#header .stuck #logo img[src$=".svg"] {
    max-width: 150px !important;
}

.header:not(.transparent) .header-nav-main.nav>li>a {
    display: inline-block;
    position: relative;
}

.header:not(.transparent) .header-nav-main.nav>li>a::after {
    content: '';
    position: absolute;
    width: 100%;
    transform: scaleX(0);
    height: 2px;
    bottom: 0;
    left: 0;
    background-color: #fff;
    transition: transform 0.25s ease-out;
}

.header:not(.transparent) .header-nav-main.nav>li>a:hover::after {
    transform: scaleX(1);
}

.header:not(.transparent) .header-nav-main.nav>li>a.nav-top-link::after {
    transform-origin: bottom right;
}

.header:not(.transparent) .header-nav-main.nav>li>a.nav-top-link:hover::after {
    transform-origin: bottom left;
}

/* underline when hover text custom */

.undeliner_effect {
    position: relative;
    display: inline-block;
    text-decoration: none;
    color: inherit;
    padding-bottom: 2px;
}

.undeliner_effect::after {
    content: '';
    position: absolute;
    width: 100%;
    transform: scaleX(0);
    height: 2px;
    bottom: 0;
    left: 0;
    background-color: var(--hover-link-color);
    transition: transform 0.25s ease-out;

}

.undeliner_effect:hover::after {
    transform: scaleX(1);
}

.undeliner_effect h1::after,
.undeliner_effect h2::after,
.undeliner_effect h3::after,
.undeliner_effect h4::after,
.undeliner_effect h5::after,
.undeliner_effect h6::after,
.undeliner_effect a::after {
    transform-origin: bottom right;
}

.undeliner_effect h1:hover::after,
.undeliner_effect h2:hover::after,
.undeliner_effect h3:hover::after,
.undeliner_effect h4:hover::after,
.undeliner_effect h5:hover::after,
.undeliner_effect h6:hover::after,
.undeliner_effect a::after {
    transform-origin: bottom left;
}

.slider_hero {
    position: relative;
    overflow: hidden;
}

.slider_hero::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 10px;
    /* background-color: var(--primary-color); */
    background: var(--background-linear-gradient);
    z-index: 2;
}

.bg_box {
    /* position: absolute;
    top: 8px;
    left: 8px;
    width: 100%;
    height: 100%;
    background-color: var(--primary-color);
    z-index: 0; */
}

.text,
.button {
    position: relative;
    z-index: 1;
}

.text_button_bn .text-box-content .text-box-content {
    position: relative;
    z-index: 0;
}

.text_button_bn .text-box-content::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 8px;
    width: 100%;
    height: 100%;
    /* background-color: var(--primary-color); */
    background: var(--background-linear-gradient);
    z-index: 0;
}

.text_button_bn .text-box-content .text-inner {
    background: #fdfcf7;
    position: relative;
    z-index: 1;
    /* Đảm bảo nó nằm trên ::before */
}


.flickity-prev-next-button svg {
    display: none;
}

/* Cài đặt chung cho nút */
.flickity-prev-next-button {
    width: 40px;
    height: 40px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 24px;
    background-color: transparent;
    border: none;
    transition: background-image 0.3s ease, transform 0.3s ease;
}

/* Nút PREV - mặc định (trắng, đậm) */
.flickity-prev-next-button.previous {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2.5' stroke='%23ffffff'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M15.75 19.5 8.25 12l7.5-7.5' /%3E%3C/svg%3E");
}

/* Nút PREV - hover (xanh #026866, đậm) */
.flickity-prev-next-button.previous:hover {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2.5' stroke='%23026866'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M15.75 19.5 8.25 12l7.5-7.5' /%3E%3C/svg%3E");
    transform: scale(1.1);
}

/* Nút NEXT - mặc định (trắng, đậm) */
.flickity-prev-next-button.next {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2.5' stroke='%23ffffff'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m8.25 4.5 7.5 7.5-7.5 7.5' /%3E%3C/svg%3E");
}

/* Nút NEXT - hover (xanh #026866, đậm) */
.flickity-prev-next-button.next:hover {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2.5' stroke='%23026866'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m8.25 4.5 7.5 7.5-7.5 7.5' /%3E%3C/svg%3E");
    transform: scale(1.1);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 400 !important;
    margin-bottom: 0px;
    color: var(--primary-color);

    /* font-family: "Open Sans", sans-serif !important; */
}

.container .section.no_padding,
.row .section.no_padding {
    padding: 0px !important;
}

blockquote,
dl,
figure,
form,
ol,
p,
pre,
ul {
    margin: 0;
    padding: 0;

}

.section.no_padding.flex_col .section-content {
    display: flex;
    flex-direction: column;
    row-gap: 8px;
}

.col_l_about .col-inner {
    display: flex;
    flex-direction: column;
    row-gap: 30px;
}

.col_l_about {
    position: relative;
    pointer-events: none;
    /* overflow: hidden; */
}

.col_l_about .bg-tilt {
    position: absolute;
    inset: 0;
    width: 600px;
    height: 600px;
    background-image: url("http://konproperty.local/wp-content/uploads/2025/05/logo_KON_no_bg_25.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    z-index: 0;
    pointer-events: auto;
    opacity: 0.3;
    scale: 1.2;
    /* không chặn hover của phần tử cha */

}

.related_projects {
    padding: 0px 6px !important;
}

.project-card {
    position: relative;
    overflow: hidden;
    border: 2px solid var(--primary-color);
    border-radius: 3px;
    overflow: visible;
}

.project-card .button_effect {
    margin-top: 8px;
}

.project-card .card-image,
.project-item {
    position: relative;
    overflow: hidden;
    transition: all 0.5s ease;
    z-index: -1;

}

.project-card .card-image img,
.project-item img {
    width: 100%;
    height: 30vh;
    max-height: 250px;
    transition: transform 0.3s ease;
    object-fit: cover;
    object-position: top;
}

/* 
.project-card .card-image::before,
.project-item::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(0deg,
            transparent,
            transparent 30%,
            #ffffff83);
    transform: rotate(-45deg);
    transition: all 0.5s ease;
    opacity: 0;
} */

/* .project-card .card-image:hover {
    transform: scale(1.02);
    box-shadow: 0 0 20px #e2c7878b;
}

.project-card .card-image:hover::before,
.project-item:hover::before {
    opacity: 1;
    transform: rotate(-45deg) translateY(100%);
} */

.project-card .icon_text {
    display: flex;
    flex-direction: row;
    align-items: start;
    column-gap: 5px;
    font-size: 14px;
    line-height: 1.4;
}

.project-card .icon_text svg {
    width: 20px;
    height: 20px;
    flex: none;
}

.gr_info {
    display: flex;
    flex-direction: column;
    row-gap: 12px;
    padding: 16px 20px 20px;
}

.gr_info .title_card {
    font-weight: 600 !important;
    margin-bottom: 0px;
    font-size: 20px;
    color: var(--color-base) !important;
}


.gr_info .gr {
    display: flex;
    flex-direction: column;
    row-gap: 8px;
}

.gr_info .info_inner {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    gap: 8px;
}

.gr_info .info_inner .gr {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    row-gap: 8px;
    width: 48%;
}

.gr_info .info_inner .gr_2 {
    width: 100%;
}

.gr_info .info_inner .gr p {
    font-weight: 400 !important;
    color: rgb(102, 102, 102);
    margin-bottom: 0px;
}

.gr_info .info_inner .gr:first-child {
    text-align: start !important;
}

.gr_info .info_inner .gr:last-child {
    text-align: right;
}

.gr_info .info_inner .gr span {
    font-weight: 600 !important;
    color: var(--button-hover-color1)
}

.blogs_section::after,
.container_ctpage::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    background: linear-gradient(180deg, #0066B200 0%, #FFFFFF 100%) !important;

}

.flex-center-col .text-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

/* From Uiverse.io by adeladel522 */
.button_effect {
    position: relative;
    transition: all 0.3s ease-in-out;
    padding-block: 6px;
    padding-inline: 12px;
    background-color: var(--primary-color);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #ffff;
    gap: 8px;
    font-weight: bold;
    border: 2px solid #ffffff4d;
    outline: none;
    overflow: hidden;
    font-size: 12px;
    text-transform: uppercase;
    width: fit-content;

    min-height: 32px;
}

.icon {
    width: 24px;
    height: 24px;
    transition: all 0.3s ease-in-out;
}

.button_effect:hover,
.form-contact input[type="submit"]:hover {
    /* transform: scale(1.01); */
    border-color: #fff9;
    color: #fff;
    background-color: var(--button-hover-color)
}

.button_effect svg,
.form-contact button[type="submit"] svg {
    width: auto;
    height: 16px;
    fill: currentColor;
    transition: all 0.3s ease-in-out;
}

.form-contact button[type="submit"]:hover svg {
    /* transform: rotate(45deg); */
    rotate: 45deg;
}

.button_effect:hover .icon {
    transform: translate(4px);
}

.button_effect:hover::before {
    animation: shine 1s ease-out infinite;
}


.button_effect::before {
    content: "";
    position: absolute;
    width: 100px;
    height: 100%;
    background-image: linear-gradient(120deg,
            rgba(255, 255, 255, 0) 30%,
            rgba(255, 255, 255, 0.8),
            rgba(255, 255, 255, 0) 70%);
    top: 0;
    left: -100px;
    opacity: 0.6;
}

.blog-card {
    background: #fff;
    border: 5px solid #fff;
    display: flex;
    flex-direction: column;
    position: relative;
    height: 100%;
}


.blog-card .badge_blog,
.project-card .badge_blog {
    position: absolute;
    content: "";
    top: 12px;
    left: -1rem;
    padding: 6px 12px;
    background: var(--primary-color);
    color: #fff;
    text-align: center;
    box-shadow: 4px 4px 15px rgba(26, 35, 126, 0.2);
    border-radius: 1px 2px 2px 0px;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.4;
}

.project-card .badge_blog {
    top: 0.5rem;
    left: 0.5rem;
}

/* badge under  */
.blog-card .badge_blog::before {
    position: absolute;
    content: '';
    background: var(--button-hover-color1);
    height: 27px;
    width: 27px;
    top: 15px;
    left: 6px;
    transform: rotate(45deg);
    z-index: -1;
}


.blog-card .card-image {
    overflow: hidden;
    width: 100%;
    /* border-radius: 3px 3px 0px 0px; */
}

.blog-card img {
    width: 100%;
    height: 30vh;
    max-height: 250px;
    object-fit: cover;
    border-radius: 1px 2px 2px 0px;
}


.blog-card .gr_info {
    padding: 20px 11px 11px;
    display: flex;
    flex-direction: column;
    row-gap: 8px;
    flex-grow: 1;
}

.blog-card .gr_info .wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-top: auto;
    gap: 8px;
}

.read-more {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    font-weight: 600;
    /* hoặc màu bạn chọn */
    transition: color 0.3s ease;
}

.read-more svg {
    width: 1em;
    height: 1em;
    transition: transform 0.3s ease;
}

.read-more:hover {
    color: var(--button-hover-color);
}

.read-more:hover svg {
    transform: translateX(2px);
}

.blog-card .title_card {
    font-size: 16px;
    font-family: "Oswald", sans-serif;
    font-weight: 600;
    color: var(--color-base);
}

.blog-card .content {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    color: var(--text-color);
    font-size: 14px;
    line-height: 1.4;
    font-weight: 400;
    margin-bottom: 0px;
}

.bg_right_left {
    position: relative;
    background: var(--primary-dark-color);
    z-index: 0;
}

.ss_ft .col-inner {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.ss_ft .col-inner .under {
    border-top: 1px solid var(--primary-dark-color);
    margin-top: auto;
    padding-bottom: 32px;
}

.col_r_0 {
    padding-right: 15px !important;
}

.bg_right_left .col {
    padding-bottom: 10px !important;
}

@media screen and (min-width:768px) {
    .bg_right_left .col {
        padding-bottom: 0px !important;
    }

    .col_r_0 {
        padding-right: 0px !important;
    }
}

.ss_ft {
    padding: 32px 3.5rem 0px !important;
}

.bds-socials {
    list-style: none;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    gap: 12px;

}

.icon-box-left .icon-box-img,
.icon-box-right .icon-box-img {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.bds-socials li {
    margin: 0px !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.container_chudautu {
    display: flex;
    flex-direction: column;
    justify-content: center;
    column-gap: 20px;
    row-gap: 30px;
    margin-bottom: 100px;
}

.container_chudautu .item {
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
}

.container_chudautu .item-left {
    /* align-items: flex-end; */
}

.container_chudautu .item-right {
    /* align-items: flex-start; */
}

.logo-box {
    width: auto;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.container_chudautu h3.title {
    text-align: center;
    margin-bottom: 20px;
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
}

.container_chudautu .imgBox {
    margin-top: auto;
}

.container_chudautu .logo {
    height: 35px;
    width: auto;
}

.container_chudautu .logo-large {
    height: 60px;
    width: auto;
}

/* Responsive cho màn lớn (lg: >=1024px) */
@media (min-width: 1024px) {
    .container_chudautu {
        flex-direction: row;
        gap: 80px;
    }

    .container_chudautu .title {
        /* margin-bottom: 40px; */
        font-size: 16px;
    }

    .container_chudautu .logo {
        height: 50px;
    }

    .container_chudautu .logo-large {
        height: 80px;
    }
}



/* Nếu muốn tạo layer riêng biệt và dễ điều khiển */
/* .bg_right_left::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to left, #f9f7f2 90%, transparent 100%);
    z-index: -1;
} */

.partner .bg-fill {
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

/* Form Contact  */
.form-contact {
    background-color: var(--primary-color);
    padding: 32px 32px 10px 32px;
    border-radius: 3px;
    max-width: 600px;
    margin: 0 auto;
    color: #333;
}

.subtitle_form {
    font-weight: 700;
    text-transform: uppercase;
    color: white;
    font-size: 16px;
    margin-bottom: 10px !important;
}

.title_form {
    font-size: 32px;
    font-weight: 800;
    color: white !important;
    margin-bottom: 8px !important;
    line-height: 1.2;
}

.form_page {
    font-size: 18px;
    font-weight: 500;
    color: var(--primary-color);
    margin-bottom: 16px !important;
}

.form-contact.no_bg input,
.form-contact.no_bg textarea {
    font-size: 14px;
}

.under_tt_form {
    font-size: 14px;
    color: white;
    margin-bottom: 24px !important;
}

.under_tt_form a {
    /* color: var(--color-base); */
    text-decoration: none;
    transition: color 0.3s ease;
}

.form-contact a:hover {
    color: var(--primary-dark-color);
}

.form-contact input,
.form-contact textarea {
    width: 100%;
    padding: 20px 20px;
    border: none;
    border-radius: 3px;
    background-color: #ffffff;
    font-size: 15px;
    margin-bottom: 16px;
    box-sizing: border-box;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
}

.form-contact textarea {
    border-radius: 3px;
    resize: none;
    height: 130px;
}

.form-contact input:focus,
.form-contact textarea:focus {
    outline: none;
    box-shadow: 0 0 0 2px var(--primary-color);
}

.form-contact button[type="submit"] {
    font-size: 14px;

}

.form-contact input[type="submit"]:hover {
    border-color: #fff9;
    color: #fff;
    background-color: var(--button-hover-color);
}

@media (max-width: 600px) {
    .title_form {
        font-size: 24px;
    }

    .form-contact {
        padding: 30px 20px;
    }

    #logo img[src$=".svg"] {
        width: 200px;
        height: auto;
        display: inline-block;
    }
}

.province-block {
    margin-bottom: 40px;
}

.province-title {
    font-size: 24px;
    color: var(--primary-dark-color);
    padding-left: 10px;
    margin-bottom: 20px;
    text-transform: uppercase;
    /* margin: 0% 0% 2% 1%; */
    padding: 0px 0px 3px 0px;
    border-style: solid;
    border-width: 0px 0px 2px 0px;
    border-color: #777777;
    max-width: 400px;
}

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

.project-item {
    border: 1px solid var(--primary-color);
    border-radius: 0px !important;
    text-align: center;
    border-radius: 4px;
    overflow: hidden;
}

.project-item a {
    background: none;
    display: inline-block;
    padding: 5px !important;
}

.project-item img {
    width: 100%;
    height: auto;
    border-radius: 4px;
    display: block;

}

.project-title {
    color: var(--button-hover-color);
    margin-top: 10px;
    font-weight: bold;
}

.parent_da_banner_text {
    position: relative;
    overflow: hidden;
}

.banner_hero .text-box {
    right: 0px !important;
    left: unset !important;
}

.parent_da_banner_text .col-inner {
    border: 2px solid var(--primary-color);
}

.parent_da_banner_text .col-inner img {
    clip-path: inset(4px);
}

.da_banner_text {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    transform: translateY(100%);
    transition: transform 0.3s ease-in-out;
    background: linear-gradient(0deg, #000000 0%, #00000000 50%, #ffffff00 100%) !important;
    clip-path: inset(4px);
}

.parent_da_banner_text:hover .da_banner_text {
    transform: translateY(0);
    /* trượt lên đúng vị trí */
}

.da_banner_text h2 {
    color: white !important;
}

.banner_listproject .col-inner {
    position: relative;
    overflow: hidden;


}

.banner_listproject .bg-fill {
    background-position: bottom;
    background-repeat: no-repeat;
    background-size: 100% auto !important;
    opacity: 0.48;
    background-attachment: fixed;

    -webkit-mask-image:
        linear-gradient(to right, transparent, black 30%, black 70%, transparent),
        linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
    -webkit-mask-composite: intersect;
    mask-image:
        linear-gradient(to right, transparent, black 30%, black 70%, transparent),
        linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
    mask-composite: intersect;
    mask-repeat: no-repeat;
    mask-size: cover;
}

.tab_projects h4,
.tab_blogs h4 {
    font-weight: 600;
    color: var(--color-base);
    margin: 40px 0px;
    font-size: 2.5em;
}

.tab_blogs h4 {
    display: none;
}

.tab-panels .panel {
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.5s ease;
    pointer-events: none;
    position: absolute;
    width: 100%;
    z-index: 0;
}

.tab-panels .panel.active {
    opacity: 1;
    transform: translateY(0);
    position: relative;
    pointer-events: auto;
    z-index: 1;
}

.tab_projects a {
    background: var(--primary-color);
    color: #fff !important;
    padding: 8px 16px !important;
    border-radius: 3px;
    border: 1px solid var(--primary-color);

}

.tab_blogs li a span {
    text-transform: uppercase;

}

.tab_blogs .tab a {
    background-color: white !important;
    color: var(--primary-color) !important;
    border: 1px solid var(--primary-color);
    padding: 6px 12px !important;
    transition: all 0.3s ease-in-out;
}

.blog-card .post-date,
.blog-card a.read-more {
    font-size: 12px;
    text-align: center;
}

.tab_blogs .blog-card .gr_info a.read-more {
    color: var(--button-hover-color) !important;
    text-decoration: none;
    font-weight: 600;
}

.grid-blog {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    /* flex-wrap: wrap; */
}

@media screen and (max-width: 1024px) {
    .grid-blog {
        grid-template-columns: repeat(2, 1fr);
    }

}

@media screen and (max-width: 768px) {
    .grid-blog {
        grid-template-columns: 1fr;
    }
}

/* .related_blog {
    background: #fff;
    border: 1px solid #eee;
    padding: 15px;
    border-radius: 8px;
} */

.tab_blogs .blog-card {
    border-style: solid;
    border-width: 0px 0px 0px 0px;
    padding: 4px 4px 4px 4px;
    box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.3);
    background: #ffffff39;
}

.tab_blogs .blog-card .gr_info a {
    text-transform: uppercase;
    color: var(--primary-color) !important;
}

.tab_blogs .card-image a {
    display: block;
    padding: 0px !important;

}

.tab_blogs .tab a:hover {
    background-color: var(--primary-color) !important;
    color: white !important;
    border: 1px solid var(--primary-color);
}

.tab_projects {}

.tab_projects .project-item a {
    background: none !important;
    border: none !important;
    padding: 6px !important;

}

.tab_projects li {
    transition: all 0.3s ease-in-out;
}

.tab_projects li.active a {
    background: white;
    color: var(--primary-color) !important;
    border: 1px solid var(--primary-color);
    border-bottom: 0px;
    border-radius: 3px 3px 0 0 !important;
    /* padding: 12px 16px !important; */
}

.tab_blogs li.active a {
    background-color: var(--primary-color) !important;
    color: white !important;
}

.tab_projects li.active span {
    position: relative;
}

.tab_projects li.active span::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 3px;
    background-color: var(--primary-color);
    bottom: -5px;
    left: 0;
}

.tab_projects li:not(.active):hover {
    transform: translateY(3px);
    border-radius: 3px 3px 0 0 !important;

}

.tab_projects li:not(.active):hover a {
    border-radius: 3px 3px 0 0 !important;

}

.tab_projects ul::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 1px;
    background-color: var(--primary-color);
    bottom: -5px;
    left: 0;

}

.grid_banner {
    margin-bottom: 40px;
}

.archive_blogs .bg-fill {
    background-position: bottom;
    background-repeat: no-repeat;
    background-size: 100% auto !important;
    opacity: 0.48;
    background-attachment: fixed;
}

.load-more-wrap {
    margin-top: 18px;
}

.timeline {
    list-style: none;
    padding: 60px 0;
    position: relative
}

.timeline a:hover {
    text-decoration: none;
    color: var(--hover-link-color)
}

.timeline:before {
    top: 0;
    bottom: 0;
    position: absolute;
    content: " ";
    width: 3px;
    background-color: var(--primary-color-second);
    left: 50%;
    margin-left: -1.5px
}

.timeline>li {
    margin-bottom: 20px;
    position: relative;
    margin-left: 0px !important;
}

.timeline>li:before,
.timeline>li:after {
    content: " ";
    display: table
}

.timeline>li:after {
    clear: both
}

.timeline>li:before,
.timeline>li:after {
    content: " ";
    display: table
}

.timeline>li:after {
    clear: both
}

.timeline>li>.timeline-panel {
    width: 46%;
    float: left;
    border: 1px solid #e0e0e0;
    border-radius: 2px;
    padding: 10px;
    position: relative;
    box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.15);
    transition: all .3s
}

.timeline>li>.timeline-panel:hover {
    box-shadow: 0px 8px 40px 0px rgba(0, 0, 0, 0.18)
}

.timeline>li>.timeline-panel:before {
    position: absolute;
    top: 26px;
    right: -15px;
    display: inline-block;
    border-top: 15px solid transparent;
    border-left: 15px solid #d6d6d6;
    border-right: 0 solid #d6d6d6;
    border-bottom: 15px solid transparent;
    content: " "
}

.timeline>li>.timeline-panel:after {
    position: absolute;
    top: 27px;
    right: -14px;
    display: inline-block;
    border-top: 14px solid transparent;
    border-left: 14px solid #fff;
    border-right: 0 solid #fff;
    border-bottom: 14px solid transparent;
    content: " "
}

.timeline>li>.timeline-badge {
    color: #fff;
    font-size: 0.8em;
    text-align: center;
    position: absolute;
    top: 23px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--primary-color);
    z-index: 100;
    line-height: 15px;
    padding: 4px 10px;
    border-radius: 3px
}

.timeline>li>.timeline-badge span {
    display: block;
    font-weight: 700
}

.timeline>.timeline-inverted>.timeline-panel {
    float: right
}

.timeline>.timeline-inverted>.timeline-panel:before {
    border-left-width: 0;
    border-right-width: 15px;
    left: -15px;
    right: auto
}

.timeline>.timeline-inverted>.timeline-panel:after {
    border-left-width: 0;
    border-right-width: 14px;
    left: -14px;
    right: auto
}

.timeline-title {
    text-align: center;
    margin-top: 10px;
    font-weight: 700;
    font-size: 16px;
    text-transform: uppercase
}

.timeline-body>p,
.timeline-body>ul {
    margin-bottom: 0
}

.timeline-body>p+p {
    margin-top: 5px
}

@media (max-width: 767px) {
    .timeline:before {
        left: 40px
    }

    .timeline>li>.timeline-panel {
        width: calc(100% - 90px);
        width: -moz-calc(100% - 90px);
        width: -webkit-calc(100% - 90px)
    }

    .timeline>li>.timeline-badge {
        left: 15px;
        margin-left: 0;
        top: 16px
    }

    .timeline>li>.timeline-panel {
        float: right
    }

    .timeline>li>.timeline-panel:before {
        border-left-width: 0;
        border-right-width: 15px;
        left: -15px;
        right: auto
    }

    .timeline>li>.timeline-panel:after {
        border-left-width: 0;
        border-right-width: 14px;
        left: -14px;
        right: auto
    }
}

.container_ctpage .section-bg.bg-loaded {
    opacity: 0.9;
    background-position: 0px -150px;
    mask-image: radial-gradient(48.94% 39.06% at 50% 50%, #FFFFFF 0%, rgb(255 255 255 / .834038) 29.41%, #fff0 100%);
    mask-size: cover;
    mask-repeat: no-repeat;
    -webkit-mask-image: radial-gradient(48.94% 39.06% at 50% 50%, #FFFFFF 0%, rgb(255 255 255 / .834038) 29.41%, #fff0 100%);
    -webkit-mask-size: cover;
    -webkit-mask-repeat: no-repeat;

}

.no_bg {
    background: none !important;
    padding: 0px;
}

.form-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}

.form-group-half {
    flex: 1 1 48%;
}

.form-group-full {
    flex: 1 1 100%;
}

@media (max-width: 768px) {
    .form-group-half {
        flex: 1 1 100%;
    }
}

.contact-info-wrapper {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    padding: 1rem 1.25rem;
}

.contact-group {
    border-bottom: 1px solid #eee;
    padding-bottom: 1rem;
}

.contact-group svg {
    width: 14px;
    height: 14px;
    fill: var(--primary-color);
    color: var(--primary-color);
    flex-shrink: 0;
    transition: fill 0.3s ease, color 0.3s ease;
}

.contact-group .contact-item:hover svg {
    fill: var(--hover-link-color);
    color: var(--hover-link-color);
}

.contact-title {
    font-weight: bold;
    margin-bottom: 1rem;
    color: var(--primary-color) !important;
    font-size: 18px;
    text-transform: uppercase;
}

.contact-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

ul li.contact-item {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 0.75rem;
    margin-left: 0px;
}

.contact-icon {
    width: 24px;
    height: 24px;
}

.contact-content {
    flex: 1;
}

.contact-content p {
    font-size: 16px;
    color: var(--text-color);
    margin: 0;
    line-height: 1.4;
    font-weight: 600;
}

.fixed-bg-section {
    position: relative;
    overflow: hidden;
}

.fixed-bg-section .bg-fixed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
    pointer-events: none;
    transform: translateZ(0);
    will-change: transform;
}


.secProduct {
    margin-bottom: 100px;
}

.secProduct .top_headline {
    display: flex;
    align-items: start;
    justify-content: space-between;
    flex-direction: column;
    text-align: center;
    margin-bottom: 30px;
    gap: 30px;
}

.top_headline a.button_effect {
    white-space: nowrap;
    flex-shrink: 0;
}

.headline01 {
    font-size: 38px;
    font-weight: 600;
    color: #00a89d;
    line-height: 1.23;
    /* margin-bottom: 25px; */
}

.start_align {
    text-align: start;
}

.headline01 span {
    font-weight: 300;
    color: #434345;
    margin-left: 20px;
}

.headline02 {
    font-size: 16px;
    font-weight: 600;
    color: #004849;
    line-height: 1.1;
    text-align: center;
    margin-bottom: 20px;
}

.headline02.style01 {
    font-size: 16px;
}

.headline03 {
    font-size: 24px;
    font-weight: 600;
    line-height: 1.3;
    color: #003b3c;
    margin-top: 15px;
    margin-bottom: 15px;
}

.headline04 {
    font-family: "Montserrat";
    font-size: 0.875rem;
    font-weight: bold;
    line-height: 1.3;
    color: #000000;
    margin-bottom: 15px;
}

.headline05 {
    font-family: "SVN-TheSeasons";
    text-align: center;
    line-height: 1.1;
    font-size: 50px;
    color: #00a89d;
    margin-bottom: 40px;
}

.headline05 span {
    display: block;
    font-size: 32px;
    font-weight: bold;
    color: #004849;
}

.col2 {
    display: flex;
    justify-content: space-between;
}

.col2>* {
    width: calc((100% - 60px) / 2);
}

.productBlock {
    display: flex;
}

.productInfo {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.productInfo.setW {
    margin-right: 60px;
    min-width: 620px;
}

.productInfo .infoTop {
    margin-bottom: 25px;
}

.productInfo .infoTopFlex {
    display: flex;
    align-items: center;
}

.productInfo .infoTop .ttl {
    font-size: 24px;
    font-weight: 600;
    color: #b9916e;
    padding-right: 15px;
    border-right: 1px solid #000000;
    margin-right: 15px;
    word-break: break-word;
    min-width: 95px;
}

.productInfo .infoTop .detail {
    font-size: 0.875rem;
    line-height: 1.7;
    color: #434345;
}

.projectSwiper .swiper-slide {
    /* width: 100% !important; */
    max-width: unset !important;
    flex-shrink: 0;
}

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

.projectSwiper {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.projectSwiper .swiper-wrapper {
    display: flex;
}

.projectSwiper .swiper-wrapper {
    display: flex !important;
    /* gap: 30px; */
}

.projectSwiper .swiper-slide {
    /* width: auto !important; */
    flex-shrink: 0;
}

.projectSwiper .swiper-slide {
    background: #fff;
    /* border: 1px solid #ccc; */
    /* padding: 20px; */
    box-sizing: border-box;
    flex-shrink: 0;
    width: auto;
    height: auto;
}

.swiper-button-next:after,
.swiper-button-prev:after {
    /* color: #fff;
    font-size: 20px; */
    content: unset;
}

.custom-swiper-button {
    background-color: #E0F4F2;
    /* Nền xanh nhạt */
    color: #00A89D;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 2px solid #00A89D;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    transition: 0.3s;
    box-shadow: 0 2px 8px rgba(0, 168, 157, 0.2);
}

.custom-swiper-button:hover {
    background-color: #00A89D;
    color: white;
    /* transform: scale(1.05); */
}


.swiper-button-next,
.swiper-button-prev {
    top: 45%;
}

.swiper-button-prev {
    left: -20px;
    /* Tùy chỉnh vị trí */
}

.swiper-button-next {
    right: -20px;
}





.main {
    overflow-x: hidden;
}

.horizontal-sliders {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    width: 100%;
    overflow-x: hidden;
    padding: 0px 14px;
}

.section_slider {
    height: 80vh;
    width: 100%;
}


.overview-section {
    background-color: #eaf3f2;
    padding: 60px 20px;
    text-align: center;
}

.overview-section h2 {
    font-size: 36px;
    margin-bottom: 20px;
    color: #00665d;
}

.overview-section p {
    font-size: 18px;
    max-width: 800px;
    margin: 0 auto;
}

.stats-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 30px;
    padding: 50px 20px;
    background-color: #ffffff;
}

.stat-box {
    background-color: #f0f0f0;
    padding: 25px;
    border-radius: 12px;
    text-align: center;
    transition: all 0.3s ease;
}

.stat-box:hover {
    background-color: #d5f2ef;
}

.stat-icon {
    font-size: 32px;
    margin-bottom: 10px;
}

.stat-icon img {
    margin: 0 auto;
}

.stat-title {
    font-size: 16px;
    color: #444;
    margin-bottom: 5px;
}

.stat-value {
    font-size: 24px;
    font-weight: bold;
    color: #00665d;
}

.feature-section {
    padding: 60px 20px;
    background-color: #f9fbfa;
    text-align: center;
}

.feature-number {
    font-size: 80px;
    font-weight: bold;
    color: #ba8554;
}

.feature-title {
    font-size: 24px;
    color: #333;
    margin-bottom: 20px;
}

.feature-desc {
    max-width: 700px;
    margin: 0 auto;
    font-size: 16px;
    line-height: 1.6;
}



/* General Page  */

.general_page h2 {}

@media screen and (min-width: 768px) {
    .secProduct .top_headline {
        flex-direction: row;
        /* align-items: flex-start; */
    }


}

@media screen and (max-width: 768px) {
    .banner_hero .fill {
        padding: 0px 20px !important;
    }

    .flickity-enabled.is-draggable .flickity-viewport {
        height: 400px !important;

    }

    .banner {
        height: 100% !important;
    }

    .banner .text-box-content h2 span {
        font-size: 60% !important;
    }

    .col2 {
        flex-direction: column;
        gap: 20px;
    }

    .productInfo.setW {
        margin-right: 0px;
        /* min-width: 400px; */
        width: 100%;
    }

    .col2>* {
        width: 100%;
    }


}

@media screen and (max-width: 1024px) {
    .productInfo.setW {
        /* margin-right: 40px; */
        min-width: 400px;
        width: 100%;
    }

}

.col_contactpage .title_form {
    font-size: 18px;
    font-weight: 500;
    color: var(--primary-color) !important;
    margin-bottom: 16px !important;
}

.col_contactpage .under_tt_form {
    color: var(--primary-color);
}

.floating-cta-wrapper {
    position: fixed;
    bottom: 120px;
    right: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    z-index: 9999;
}

.cta-btn {
    width: 50px;
    height: 50px;
    background-color: #00a89d;
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
    transition: all 0.3s ease;
}

.cta-btn:hover {
    background-color: var(--primary-dark-color);
    /* opacity: 0.8; */
    transform: scale(1.05);
}

.cta-btn:hover i {
    color: var(--gold-color);
}

.cta-btn i {
    font-size: 18px;
}

/* Responsive */
@media (max-width: 768px) {
    .cta-btn {
        width: 44px;
        height: 44px;
    }

    .cta-btn i {
        font-size: 16px;
    }
}

/* Base Styles */
.section_slider {
    height: auto;
    display: flex;
    justify-content: center;
    padding-top: 30px;
    background-color: white;
}

.container-fluid {
    display: flex;
    flex-direction: column;
    gap: 24px;
    justify-content: flex-end;
    width: 100%;
    padding-right: 0;
}

/* Text Content */
.slider-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 16px;
}

.slider-title {
    padding: 8px 0;
    font-size: 24px;
    line-height: 1.2;
    font-weight: 600;
    border-bottom: 1px solid #006162;
    color: #00A89D;
    width: max-content;
}

.slider-description {
    font-size: 13px;
    line-height: 1.5;
    width: 100%;
}

/* Image Gallery */
.image-gallery {
    display: flex;
    width: 100%;
    overflow: hidden;
    aspect-ratio: 16/9;
}

.column-images {
    display: flex;
    flex-direction: column;
    width: 50%;
    height: 100%;
}

.image-container {
    border: 5px solid white;
    position: relative;
    width: 100%;
    height: 50%;
}

.image-container img {
    position: absolute;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.top-image img {
    object-position: right;
    border-top-left-radius: 40px;
}

.bottom-image img {
    object-position: center;
    border-bottom-left-radius: 60px;
}

.main-image-container {
    border: 5px solid white;
    position: relative;
    width: 50%;
    height: 100%;
}

.main-image-container img {
    position: absolute;
    top: 0;
    object-position: center;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/* Animations */
.wow {
    visibility: visible;
    animation-duration: 0.7s;
    animation-delay: 0.1s;
}

/* Responsive - Large devices (lg) */
@media (min-width: 1024px) {
    .section_slider {
        padding-top: 10px;
    }

    .container-fluid {
        flex-direction: row;
        padding-right: 0 !important;
        justify-content: center;
    }

    .slider-content {
        width: 50%;
        max-width: 460px;
        padding: 16px 24px;
        gap: 16px;
    }

    .slider-title {
        font-size: 32px;
        line-height: 39px;
    }

    .slider-description {
        font-size: 14px;
        line-height: 22px;
        max-width: 349px;
    }

    .image-gallery {
        aspect-ratio: auto;
        width: 50%;
    }

    .column-images {
        width: auto;
    }

    .image-container {
        width: 386px;
        /* height: 247px; */
    }


    .bottom-image img {
        border-bottom-left-radius: 120px;
    }

    .top-image img {
        border-top-left-radius: 80px;
    }

    .main-image-container {
        width: 437px;
        /* height: 534px; */
    }

    .main-image-container img {
        object-position: right;
    }
}

/* Responsive - Extra large devices (xl) */
@media (min-width: 1280px) {
    .section_slider {
        padding-top: 10px;
    }

    .slider-content {
        height: 320px;
        gap: 40px;
        padding: 16px;
    }
}

.riverpark-section {
    height: auto;
    display: flex;
    background-color: white;
}

.riverpark-container {
    display: flex;
    flex-direction: column;
    gap: 24px;
    justify-content: flex-start;
    width: 100%;
    padding-left: 0;
}

/* Text Content - River Park */
.riverpark-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 16px;
    order: 1;
}

.riverpark-title {
    padding-bottom: 8px;
    font-size: 24px;
    line-height: 1.2;
    font-weight: 600;
    border-bottom: 1px solid #006162;
    color: #00A89D;
    width: max-content;
}

.riverpark-description {
    font-size: 13px;
    line-height: 1.5;
    width: 100%;
}

.view-more {
    background-color: #00A89D;
    color: #fff;
    font-size: 0.875rem;
    line-height: 22px;
    border-radius: 7px;
    padding: 10px 20px;
    display: inline-block;
    text-decoration: none;
}

/* Image Gallery - River Park */
.riverpark-gallery {
    display: flex;
    flex-direction: column;
    width: 100%;
    overflow: hidden;
    aspect-ratio: 16/9;
    order: 2;
}

.top-row-images {
    display: flex;
    width: 100%;
    height: 33.33%;
}

.riverpark-image-container {
    border: 5px solid white;
    position: relative;
    width: 50%;
    height: 100%;
}

.riverpark-image-container img {
    position: absolute;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.left-image img {
    object-position: right;
}

.right-image img {
    object-position: center;
    border-top-right-radius: 42px;
}

.large-image-container {
    border: 5px solid white;
    position: relative;
    width: 100%;
    height: 66.66%;
}

.large-image-container img {
    position: absolute;
    top: 0;
    object-position: left;
    object-fit: cover;
    width: 100%;
    height: 100%;
    border-bottom-right-radius: 60px;
}

/* Animations */
.wow {
    visibility: visible;
    animation-duration: 0.7s;
    animation-delay: 0.1s;
}

/* Responsive - Large devices (lg) */
@media (min-width: 1024px) {
    .horizontal-sliders {
        display: flex;
        flex-wrap: nowrap;
        flex-direction: row;
        width: 600%;
        overflow-x: hidden;
        padding: unset;

    }

    .riverpark-container {
        flex-direction: row;
        padding-left: 0 !important;
    }

    .riverpark-content {
        width: 50%;
        max-width: 460px;
        padding: 16px 24px;
        gap: 16px;
        padding-top: 28px;
        order: 2;
    }

    .riverpark-title {
        font-size: 32px;
        line-height: 39px;
    }

    .riverpark-description {
        font-size: 14px;
        line-height: 22px;
        max-width: 344px;
    }

    .riverpark-gallery {
        aspect-ratio: auto;
        width: 50%;
        order: 1;
    }

    .top-row-images {
        height: auto;
    }

    .riverpark-image-container {
        width: 407px;
        height: 187px;
    }

    .right-image {
        width: 414px;
    }

    .right-image img {
        border-top-right-radius: 84px;
    }

    .large-image-container {
        width: 821px;
        height: 412px;
    }

    .large-image-container img {
        border-bottom-right-radius: 119px;
    }
}

/* Responsive - Extra large devices (xl) */
@media (min-width: 1280px) {
    .riverpark-container {
        gap: 40px;
    }

    .riverpark-content {
        height: 320px;
        gap: 40px;
        padding: 16px;
    }
}