.miv-grid {
    display: grid;
    grid-template-columns: repeat(var(--miv-cols,6), 1fr);
    gap: 25px;
    margin: 20px 0;
}

.miv-card {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid #ddd;
    text-align: left;
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
    display:flex;
    flex-direction:column;
    height:100%;
}

.miv-thumb img {
    width: 100%;
    height: 160px;
    object-fit: cover;
    display: block;
}

.miv-body {
    padding: 12px;
    margin-top:auto;
}

.miv-title {
    margin: 0 0 6px;
    font-size: 15px;
}

.miv-cat {
    font-size: 13px;
    color: #777;
    margin-bottom: 8px;
}

/* vote area: button and learn more below it */
.miv-vote-area {
    margin-top: 10px;
    display:flex;
    flex-direction:column;
    gap:6px;
}

.miv-vote-btn {
    background: #2f6fb3;
    color: #fff;
    padding: 10px 12px;
    border: 0;
    border-radius: 6px;
    cursor: pointer;
    width: 100%;
    font-size: 14px;
    display:block;
    text-align:center;
}

.miv-learn-more {
    display:inline-block;
    text-align:center;
    padding:8px 10px;
    border-radius:6px;
    background:#fff;
    color:#2f6fb3;
    border:1px solid #2f6fb3;
    text-decoration:none;
    font-size:13px;
}

.miv-learn-more.disabled {
    background:#f4f4f4;
    color:#999;
    border-color:#ddd;
    display:inline-block;
    padding:8px 10px;
    border-radius:6px;
}

.miv-modal{position:fixed;left:50%;top:30%;transform:translate(-50%, -30%);background:#fff;padding:20px;border-radius:6px;box-shadow:0 6px 20px rgba(0,0,0,.3);z-index:9999;display:none}
.miv-modal button{margin-top:10px}
.miv-overlay{position:fixed;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,0.4);z-index:9998;display:none}
