/* ============================================================
   VLIG Category Loop — Frontend Styles v1.2.0
   ============================================================ */

/* === Grid ====================================================== */
.vcl-wrapper .vcl-grid {
    display: grid;
    grid-template-columns: repeat(var(--vcl-col-d, 4), 1fr);
    gap: var(--vcl-gap, 24px);
    margin: 0;
}
@media (max-width: 1024px) {
    .vcl-wrapper .vcl-grid { grid-template-columns: repeat(var(--vcl-col-t, 2), 1fr); }
}
@media (max-width: 767px) {
    .vcl-wrapper .vcl-grid { grid-template-columns: repeat(var(--vcl-col-m, 1), 1fr); }
}

/* === Swiper ==================================================== */
.vcl-wrapper .vcl-swiper        { padding-bottom: 40px; }
.vcl-wrapper .swiper-slide       { height: auto; }
.vcl-wrapper .vcl-nav-prev,
.vcl-wrapper .vcl-nav-next       { color: var(--vcl-accent, #0A7AAE); }
.vcl-wrapper .vcl-nav-prev::after,
.vcl-wrapper .vcl-nav-next::after { font-size: 1.4rem; font-weight: 700; }
.vcl-wrapper .vcl-pagination .swiper-pagination-bullet-active {
    background: var(--vcl-accent, #0A7AAE);
}

/* === Kartica =================================================== */
.vcl-wrapper .vcl-card {
    position: relative;
    display: block;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    height: 100%;
}

/* Plava linija dno */
.vcl-wrapper .vcl-card.vcl-corner::before {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 100%; height: 8px;
    background-color: var(--vcl-accent, #0A7AAE);
    z-index: 4;
    transition: background-color 0.25s ease;
}
/* Trougao dno desno */
.vcl-wrapper .vcl-card.vcl-corner::after {
    content: '';
    position: absolute;
    bottom: 0; right: 0;
    border-bottom: 60px solid var(--vcl-accent, #0A7AAE);
    border-left: 60px solid transparent;
    z-index: 4;
    transition: border-bottom-color 0.25s ease, border-left-color 0.25s ease;
}
.vcl-wrapper .vcl-card.vcl-corner:hover::after {
    border-bottom-color: transparent;
    border-left-color: transparent;
}
.vcl-wrapper .vcl-card.vcl-corner:hover::before {
    background-color: #86BDD7;
}

/* === Slika ===================================================== */
.vcl-wrapper .vcl-image-wrap {
    width: 100%;
    aspect-ratio: var(--vcl-ratio, 4/3);
    overflow: hidden;
    display: block;
}
.vcl-wrapper .vcl-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.vcl-wrapper .vcl-no-image {
    width: 100%;
    height: 100%;
    background: #c8d8e0;
}

/* === Stalni tamni gradient ===================================== */
.vcl-wrapper .vcl-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        transparent 0%,
        transparent 30%,
        rgba(0, 0, 0, 0.55) 100%
    );
    z-index: 2;
    pointer-events: none;
}

/* === Plavi slide-up overlay (hover) =========================== */
.vcl-wrapper .vcl-hover-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 122, 174, 0.5);
    z-index: 3;
    transform: translateY(100%);
    transition: transform 0.4s ease;
    pointer-events: none;
}
.vcl-wrapper .vcl-card:hover .vcl-hover-overlay {
    transform: translateY(0%);
}

/* === Title wrap ================================================ */
/*
   Pozicioniran na dnu kartice.
   Na hover: translateY(--vcl-title-offset) koji JS izračunava
   kao negativna vrednost = -(visina kartice - 20px padding gore - visina title-wrap)
   čime title završi tik uz gornji rub.
*/
.vcl-wrapper .vcl-title-wrap {
    position: absolute;
    bottom: 36px;
    left: 0;
    width: 100%;
    padding: 0 18px;
    box-sizing: border-box;
    z-index: 5;
    transform: translateY(0px);
    transition: transform 0.4s ease;
    pointer-events: none;
}
.vcl-wrapper .vcl-card:hover .vcl-title-wrap {
    transform: translateY(var(--vcl-title-offset, -200px));
}

/* Naslov */
.vcl-wrapper .vcl-title {
    color: var(--vcl-title-color, #fff);
    font-size: var(--vcl-title-size, 1.4rem);
    font-weight: 700;
    margin: 0 0 6px 0;
    line-height: 1.25;
    display: block;
}

/* Broj postova */
.vcl-wrapper .vcl-count {
    display: block;
    color: rgba(255,255,255,0.8);
    font-size: 0.8rem;
    margin: 0;
}

/* === Link wrap — fiksan na dnu, ne pomera se ================== */
.vcl-wrapper .vcl-link-wrap {
    position: absolute;
    bottom: 20px;
    left: 18px;
    z-index: 5;
}
.vcl-wrapper .vcl-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--vcl-link-color, #fff);
    font-size: 0.9rem;
    font-weight: 400;
    opacity: 0.9;
    transition: opacity 0.2s ease, gap 0.2s ease;
}
.vcl-wrapper .vcl-card:hover .vcl-link {
    opacity: 1;
    gap: 8px;
}
.vcl-wrapper .vcl-arrow {
    font-size: 1.1rem;
    line-height: 1;
    transition: transform 0.2s ease;
}
.vcl-wrapper .vcl-card:hover .vcl-arrow {
    transform: translateX(3px);
}
