.umbr-carousel {
    width: 100%;
    overflow: hidden;
    position: relative;
}

.umbr-track {
    display: flex;
    gap: 20px;
    transition: transform .4s cubic-bezier(.25,.46,.45,.94);
    will-change: transform;
}

/* Card */
.umbr-card {
    flex: 0 0 calc(33.333% - 14px);
    background: #fff;
    border: 1px solid #e8edf3;
    border-radius: 14px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    box-sizing: border-box;
}

.umbr-card__stars { display: flex; gap: 2px; }
.umbr-star       { font-size: 15px; color: #e2e8f0; }
.umbr-star--on   { color: #f59e0b; }

.umbr-card__text {
    font-size: 14.5px;
    line-height: 1.7;
    color: #475569;
    margin: 0;
    flex: 1;
}

.umbr-card__name {
    font-size: 13px;
    font-weight: 600;
    color: #0f172a;
    margin-top: auto;
}

/* Nav */
.umbr-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-top: 24px;
}

.umbr-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid #e2e8f0;
    background: #fff;
    color: #64748b;
    font-size: 16px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: border-color .15s, color .15s;
    line-height: 1;
}
.umbr-btn:hover { border-color: #94a3b8; color: #0f172a; }

.umbr-dots { display: flex; gap: 6px; }
.umbr-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #e2e8f0;
    cursor: pointer;
    transition: background .2s, transform .2s;
}
.umbr-dot--active { background: #2563eb; transform: scale(1.3); }

/* Responsive: 2 cards on tablet, 1 on mobile */
@media (max-width: 780px) {
    .umbr-card { flex: 0 0 calc(50% - 10px); }
}
@media (max-width: 480px) {
    .umbr-card { flex: 0 0 100%; }
}
