.blog-carousel-container {
    position: relative;
    /* Add side padding so cards don't sit underneath nav buttons */
    /* padding: 30px 0px; */
    margin-top: 30px !important;
}

.blog-carousel-container .default-content-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    /* padding: 0 24px 40px 24px; */
}

.blog-carousel-container .default-content-wrapper h1 {
    margin: 0;
    font-size: 32px;
}

.blog-carousel-wrapper {
    display: flex;
    align-items: center;
    overflow: hidden;
    margin: 0;
}

.blog-carousel-track {
    display: flex;
    flex-wrap: nowrap;
    gap: 30px;
    transition: transform 0.3s ease;
    border: 0;
    border-radius: 0;
}

.blog-carousel-container a {
    font-size: 16px;
    font-weight: 700;
    font-family: var(--body-font-family-bold);
    /* padding: 12px 32px;
    background: linear-gradient(to left, #e5461c, #ee6f32); */
}

/* In two_card_carousel, split slide width between 2 cards horizontally */
.blog-carousel-track.two_card_carousel {
    gap: 25px;
}

.blog-carousel-track.two_card_carousel
    .blog-carousel-slide
    .blog-carousel-card {
    width: auto;
    flex: 0 0 calc((100% - 60px) / 2);
    max-width: calc((100% - 60px) / 2);
}

/* Each slide is a COLUMN containing 2 stacked cards */
.blog-carousel-slide {
    display: flex;
    flex-direction: column;
    gap: 60px;
    align-items: stretch;
}

/* Mode: two cards visible (1 column between buttons) */
.blog-carousel-track.two_card_carousel .blog-carousel-slide {
    flex: 0 0 100%;
    flex-direction: row;
    /* show 2 cards side-by-side in a row on desktop */
}

/* Mode: four cards visible (2 columns between buttons) */
.blog-carousel-track.four_card_carousel .blog-carousel-slide {
    flex: 0 0 calc((100% - 30px) / 2);
    flex-direction: column;
    /* 2 stacked cards per column */
}

.blog-carousel-card {
    box-sizing: border-box;
    min-width: 0;
    /* prevent content overflow */
    width: auto;
    /* allow mode-specific flex-basis to control size */
    height: auto;
    background: #fff;
    border-radius: 12px;
    display: flex;
    flex: 0 0 auto;
    border: 1px solid #e2dcdc;
    overflow: hidden;
}

.blog-carousel-card:hover {
    border-color: #e5461c;

    /* border-image-source: linear-gradient(270deg, #E5461C 0%, #EE6F32 100%); */
    box-shadow: 0px 4px 16px 0px rgba(17, 17, 17, 0.08);
}

.blog-carousel-card-text {
    flex: 1;
    padding: 30px;
    padding-right: 0;
}

.our-purpose-cards .blog-carousel-card-text {
    padding-right: 30px;
}

.blog-carousel-card-date {
    font-weight: 500;
    font-size: 14px;
    line-height: 130%;
    color: grey;
}

.blog-carousel-card-title {
    /* width: 80%; */
    font-weight: 600;
    /* font-size: 24px; */
    font-size: 22px;
    line-height: 130%;
    color: #111111;
}

.blog-carousel-card-title p,
.blog-carousel-card-title p a {
    font-family: var(--body-font-family-semibold);
    font-size: 16px;
    line-height: 130%;
    font-weight: 600;
    margin-top: 0;
    color: #111111;
    border: none;
    padding: 0;
    text-align: left;
    background: none;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-carousel-card-title p a:hover {
    background: none !important;
}

.blog-carousel-card-image {
    /* border-radius: 12px; */
    overflow: hidden;
    margin-left: 16px;
}

.blog-carousel-card-image img {
    /* width: 176px; */
    height: 100%;
    object-fit: cover;
    /* 🆕 Ensures proper image scaling */
}

.blog-carousel-nav {
    background: #fff;
    border-radius: 32px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    z-index: 10;
    transition: box-shadow 0.2s ease;
}

/* Fixed positioning for navigation buttons - outside the wrapper */
.blog-carousel-nav.left {
    left: -20px;
    position: absolute;
}

.blog-carousel-nav.right {
    right: -21px;
    position: absolute;
}

.blog-carousel-nav.left::before {
    content: "\2039";
    /* left arrow */
    font-size: 28px;
    font-weight: 100;
    color: #666;
    position: absolute;
    top: 7px;
}

.blog-carousel-nav.right::before {
    content: "\2039";
    /* reuse same char */
    font-size: 28px;
    font-weight: 100;
    color: #666;
    position: absolute;
    top: 30%;
    transform: rotate(180deg);
}

/* Our Purpose & Principles */

.our-purpose-cards .blog-carousel-card {
    flex-direction: row-reverse;
}

.our-purpose-cards .blog-carousel-card:hover {
    border: 1px solid #1111111f;
}

.our-purpose-cards .blog-carousel-card-image {
    margin: 0;
}

.our-purpose-cards .blog-carousel-card-title p {
    font-size: 18px !important;
    line-height: 130%;
    opacity: 0.6;
}

.our-purpose-cards .blog-carousel-card-date {
    font-size: 20px;
    line-height: 130%;
    color: rgba(167, 14, 21, 1);
    font-weight: 700;
    margin-bottom: 12px;
}

.our-purpose-cards .blog-carousel-slide .blog-carousel-card {
    width: 100% !important;
}

.our-purpose-cards .blog-carousel-track.two_card_carousel .blog-carousel-slide {
    max-width: 100%;
}

.our-purpose-cards .blog-carousel-card-title p {
    opacity: 0.6;
}

.our-purpose-cards .blog-carousel-card-image img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

/* .blog-carousel-card:hover {
    transform: translateY(-4px);
    transition: transform 0.3s ease;
} */

@media (max-width: 1024px) {
    .blog-carousel-track.two_card_carousel
        .blog-carousel-slide
        .blog-carousel-card {
        flex: 0 0 calc((98% - 60px) / 2);
        max-width: calc((98% - 60px) / 2);
    }

    .blog-carousel-slide {
        gap: 40px;
    }

    .blog-carousel-nav.right {
        right: 21px;
    }
}

@media screen and (max-width: 767px) {
    .our-purpose-cards .blog-carousel-card {
        flex-direction: row-reverse;
        border: 0;
    }

    .blog-carousel-card-text {
        padding: 10px 10px;
    }

    .blog-carousel-container .default-content-wrapper {
        flex-direction: column;
        align-items: flex-start;
    }

    .blog-carousel-container .default-content-wrapper h1 {
        font-size: 24px;
    }

    .blog-carousel-card-title .button-container {
        padding: 0 !important;
    }

    .blog-carousel-container .button-container {
        width: 100%;
        display: inline-block;
        padding: 0 16px;
        margin-top: 20px;
    }

    .blog-carousel-container .button-container strong {
        width: 100%;
    }

    .blog-carousel-container .button-container a {
        width: 100%;
        /* display: inline-block; */
    }

    .blog-carousel-wrapper {
        margin: 0;
        /* Remove desktop margins */
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        scroll-snap-type: x mandatory;
        /* snap at wrapper level */
        scroll-padding-inline: 10px;
        /* align first/last slides to edges */
        scroll-behavior: smooth;
    }

    /* Our Purpose & Principles */

    .our-purpose-cards .blog-carousel-card {
        flex-direction: row-reverse;
        border: 0;
    }

    .our-purpose-cards .blog-carousel-card:hover {
        border: unset;
    }

    .our-purpose-cards .blog-carousel-card-image {
        margin: 0;
        width: 30%;
    }

    .our-purpose-cards .blog-carousel-card-title p {
        line-height: 130%;
        opacity: 0.6;
    }

    .our-purpose-cards .blog-carousel-card-date {
        font-size: 16px;
        line-height: 130%;
        color: rgba(167, 14, 21, 1);
        font-weight: 700;
        margin-bottom: 6px;
    }

    .our-purpose-cards .blog-carousel-card-title p {
        font-size: 14px !important;
        opacity: 0.6;
    }

    .our-purpose-cards .blog-carousel-card-image img {
        height: 100%;
        width: 100%;
        object-fit: cover;
    }

    .blog-carousel-container .default-content-wrapper {
        flex-direction: column;
        align-items: flex-start;
        padding-bottom: 0;
    }

    .blog-carousel-container .default-content-wrapper h1 {
        font-size: 24px;
    }

    .our-purpose-cards .blog-carousel-card-title p {
        font-size: 14px !important;
    }

    .blog-carousel-wrapper::-webkit-scrollbar {
        display: none;
    }

    .blog-carousel-track {
        display: flex;
        /* horizontal track */
        flex-wrap: nowrap;
        gap: 30px;
        /* match JS mobile gap */
        overflow-x: visible;
        /* track can exceed container */
        width: auto;
        /* Allow track to expand */
    }

    /* Column width and snap on mobile */
    .blog-carousel-track.four_card_carousel .blog-carousel-slide {
        flex: 0 0 calc((150% - 10px) / 2);
        scroll-snap-align: start;
        scroll-snap-stop: always;
        flex-direction: column !important;
        gap: 22px;
        /* always stack 2 vertically on mobile */
    }

    .blog-carousel-card-date {
        font-size: 12px;
    }

    /* Two-card mode: scroll one card at a time on mobile */
    .blog-carousel-track.two_card_carousel .blog-carousel-slide {
        /* Flatten slide so its cards become direct flex items of the track */
        display: flex;
        flex-direction: column;
        gap: 22px;
        max-width: 83% !important;
    }

    .blog-carousel-track.two_card_carousel .blog-carousel-card {
        /* Each card takes full viewport width and is a snap target */
        flex: 0 0 100%;
        scroll-snap-align: start;
        scroll-snap-stop: always;
    }

    .blog-carousel-track.two_card_carousel
        .blog-carousel-slide
        .blog-carousel-card {
        width: 100%;
        /* flex: 100%; */
        max-width: 100%;
        justify-content: space-between;
    }

    .blog-carousel-card {
        width: 100%;
        min-height: 104px;
    }

    .blog-carousel-card-title {
        font-size: 14px;
        width: 100%;
        margin: 0;
    }

    .blog-carousel-card-image {
        border-radius: 0 8px 8px 0;
    }

    .blog-carousel-card-image img {
        width: 104px;
        height: 100%;
    }

    .blog-carousel-card-title p,
    .blog-carousel-card-title p a {
        margin: 0;
        font-size: 14px !important;
        font-family: var(--body-font-family-medium);
        font-weight: 500 !important;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .blog-carousel-nav {
        display: none;
    }
    .carousel-dots {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 8px;
        margin-top: 12px;
        transition: all 0.3s ease-in-out;
    }

    .dots-value {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #d0d0d0;
        transition: all 0.35s cubic-bezier(0.25, 1, 0.5, 1);
        opacity: 0.7;
    }

    .dots-value.active {
        background: linear-gradient(to bottom right, #8e0006, #4e0003);
        width: 24px;
        border-radius: 10px;
        height: 7px;
        opacity: 1;
        transform: scale(1.05);
    }

    .blog-carousel-wrapper {
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth; /* ✅ smooth swipe transition */
    }

    .blog-carousel-slide {
        scroll-snap-align: start;
        transition: transform 0.4s ease-in-out; /* ✅ subtle animation on move */
    }

    .our-purpose-cards .blog-carousel-card-text{
        padding-right: 8px;
    }
}
