.vcm-carousel { position: relative; width: 100%; margin: 0 auto; overflow: hidden; border-radius: 16px; background: #101010; color: #ffffff; box-shadow: 0 10px 30px rgba(0,0,0,.15); }
.vcm-track { position: relative; }
.vcm-slide { display: none; }
.vcm-slide.active { display: block; }
.vcm-video-wrap { position: relative; width: 100%; padding-top: 56.25%; background: #000; }
.vcm-video-wrap video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; background: #000; }
.vcm-content { padding: 16px 18px; }
.vcm-title { margin: 0 0 8px; font-size: 1.125rem; line-height: 1.3; font-weight: 700; }
.vcm-desc { font-size: .95rem; line-height: 1.6; opacity: .95; }
.vcm-controls { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; padding: 0 18px 18px; }
.vcm-buttons, .vcm-dots { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.vcm-btn { appearance: none; border: 0; border-radius: 10px; background: #ffffff; color: #111111; padding: 9px 14px; cursor: pointer; font-size: .92rem; font-weight: 600; }
.vcm-btn:hover { opacity: .92; }
.vcm-dot { width: 10px; height: 10px; border-radius: 999px; border: 0; background: rgba(255,255,255,.35); cursor: pointer; padding: 0; }
.vcm-dot.active { background: #ffffff; }
.vcm-empty { padding: 20px; border-radius: 12px; background: #f4f4f4; color: #333; }
@media (max-width: 767px) {
    .vcm-content { padding: 14px; }
    .vcm-controls { padding: 0 14px 14px; }
    .vcm-btn { padding: 8px 12px; font-size: .88rem; }
}
