/* ==========================
   GLOBAL RESET / BASE
========================== */
.calmhaven-post-carousel-wrapper,
.calmhaven-carousel-post,
.calmhaven-overlay-post,
.calmhaven-carousel-post img,
.calmhaven-overlay-post img,
.calmhaven-btn,
.calmhaven-date,
.calmhaven-author,
.calmhaven-time,
.calmhaven-comments,
.calmhaven-overlay-content h3,
.calmhaven-overlay-content p {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* Flex wrapper for additional data */
.calmhaven-meta-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: inherit; /* inherit alignment from parent */
}

.calmhaven-meta-wrapper span {
    display: inline-flex;
    align-items: center;
    margin: 0;
}

/* Carousel wrapper */
.calmhaven-post-carousel-wrapper {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
}

.swiper-container {
    width: 100%;
    overflow: hidden;
}

.swiper-wrapper {
    display: flex;
    gap: 0px;
}

.swiper-slide {
  display: flex !important;
    justify-content: flex-start;
    width: auto; /* controlled by JS */
}

/* Post card */
.calmhaven-carousel-post,
.calmhaven-overlay-post {
    width: 100%;
    text-align: inherit;
}

/* Carousel layout */
.calmhaven-carousel-post {
    display: flex;
    flex-direction: column;
    align-items: unset; 
    padding: 10px;
    box-sizing: border-box;
    text-align: inherit;
}

.calmhaven-carousel-post img {
    display: block;
    margin-bottom: 10px;
    width: 100%;
    height: auto;
    object-fit: cover; /* optional: crop nicely */
}

.calmhaven-btn {
    display: inline-block;
    padding: 6px 12px;
    background-color: #0073aa;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    white-space: nowrap;
    margin-top: 5px;
    text-align: center;
}

/* Carousel button wrapper */
.calmhaven-carousel-post .calmhaven-btn-wrapper {
    display: block;
    width: 100%;
    text-align: inherit;
}

/* Carousel button itself */
.calmhaven-carousel-post .calmhaven-btn {
    display: inline-block;
    width: auto;
    padding: 6px 12px;
    margin: 0;
    text-align: center;
}

/* Additional data */
.calmhaven-date,
.calmhaven-author,
.calmhaven-time,
.calmhaven-comments {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-right: 8px;
    text-align: inherit;
}

/* Overlay layout */
.calmhaven-overlay-post {
    position: relative;
    overflow: hidden;
}

.calmhaven-overlay-post img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover; /* optional: crop nicely */
}

.calmhaven-overlay-content {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    color: #fff;
    opacity: 0;
    transition: opacity 0.3s ease;
    padding: 15px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: flex-start; /* keep flow like carousel */
    align-items: unset;          /* don’t override text-align */
    text-align: inherit;         /* Elementor alignment cascades */
}

/* Overlay content container */
.calmhaven-overlay-content {
    display: block;       /* change from flex to block */
    width: 100%;
    padding: 15px;
    text-align: inherit;  /* allows left/center/right alignment */
}

/* Make each field block */
.calmhaven-overlay-content h3,
.calmhaven-overlay-content p,
.calmhaven-overlay-content .calmhaven-btn-wrapper,
.calmhaven-overlay-content .calmhaven-date,
.calmhaven-overlay-content .calmhaven-author,
.calmhaven-overlay-content .calmhaven-time,
.calmhaven-overlay-content .calmhaven-comments {
    display: block;       /* force block, no flex/grid behavior */
    width: 100%;          /* optional: keep full width for alignment */
    margin-bottom: 10px;  /* spacing between fields */
}

/* Button wrapper to handle text alignment */
.calmhaven-btn-wrapper {
    text-align: inherit; /* left, center, right from style tab */
}

.calmhaven-overlay-post:hover .calmhaven-overlay-content {
    opacity: 1;
}

.calmhaven-overlay-content h3 a {
    color: #fff;
    text-decoration: none;
    margin: 5px 0;
}


.calmhaven-overlay-content .calmhaven-btn {
    display: inline-block;
    width: auto;
    padding: inherit;
    margin: 0;
    flex: 0 0 auto;
    text-align: center;
}

/* Ensure slides inside overlay respond like carousel */
.swiper-slide .calmhaven-overlay-post {
    flex: 0 0 auto; /* let JS calculate width dynamically */
}

.calmhaven-post-carousel img,
.calmhaven-overlay-post img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

@media (max-width: 768px) {
    .swiper-slide,
    .calmhaven-post-carousel .swiper-slide {
        width: 100% !important;
        margin: 0;
    }
}

.calmhaven-post-carousel .swiper-slide:first-child {
    margin-left: 0 !important;
}
.calmhaven-post-carousel .swiper-slide.swiper-slide-duplicate {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

