/* ThePoint Grid/Slider Widget */

.tp-gs-widget *, .tp-gs-widget *::before, .tp-gs-widget *::after { box-sizing: border-box; }

/* ── Card ─────────────────────────────────────────────────── */
.tp-card {
    display: flex;
    flex-direction: column;
    align-items: stretch; /* overridden by Elementor selector per widget */
    border-radius: 12px;
    overflow: hidden;
    transition: transform .25s ease, box-shadow .25s ease;
}

.tp-card *{
    user-select: none;
    -webkit-user-drag: none;
}

/* ── Image ────────────────────────────────────────────────── */
.tp-card__image {
    display: block;
    width: 100%;
    height: 180px;
    object-fit: cover;
    object-position: center;
    flex-shrink: 0;
}
.tp-card__image-link {
    display: block;
    flex-shrink: 0;
    line-height: 0;
    align-self: stretch; /* always stretch link wrapper regardless of card align */
}
.tp-card__image-link .tp-card__image { width: 100%; }

/* ── Text body ────────────────────────────────────────────── */
.tp-card__body {
    padding: 24px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-self: stretch; /* always full width regardless of card align-items */
}

/* ── Title ────────────────────────────────────────────────── */
.tp-card__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.2;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.tp-card__title a { color: inherit; text-decoration: none; }

/* ── Description ──────────────────────────────────────────── */
.tp-card__desc {
    margin: 0;
    font-size: .85rem;
    line-height: 1.5;
    color: rgba(255,255,255,.75);
}

/* ── Grid desktop ─────────────────────────────────────────── */
.tp-grid { display: grid; }

/* ── Slider mobile ────────────────────────────────────────── */
.tp-slider-wrap { display: none; overflow: hidden; }
.tp-slider-wrap .swiper { overflow: visible; }
.tp-gs-widget { overflow-x: clip; }
.tp-slider-wrap .swiper-slide { height: auto; }
.tp-slider-wrap .tp-card { height: 100%; }

/* ── ACF Tags Widget ─────────────────────────────────────────────────────── */
.tp-acf-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.tp-acf-tag {
    display: inline-block;
    background-color: #fff;
    color: #111;
    border-radius: 999px;
    padding: 8px 20px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
}

