/* videos.css */
.video-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 760px; margin: 0 auto; }
@media (max-width: 400px) { .video-grid { grid-template-columns: 1fr; } }

.video-thumb {
  position: relative; cursor: pointer; border-radius: 10px; overflow: hidden;
  aspect-ratio: 16/9; background: #0d2b1e;
  border: 2px solid rgba(201,168,76,.25);
  transition: transform .2s, box-shadow .2s;
}
.video-thumb:hover { transform: scale(1.02); box-shadow: 0 8px 24px rgba(0,0,0,.4); }
.vt-img { width: 100%; height: 100%; object-fit: cover; opacity: .65; transition: opacity .3s; }
.video-thumb:hover .vt-img { opacity: .85; }
.vt-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,30,18,.9) 0%, transparent 60%);
  opacity: .8; transition: opacity .3s;
}
.play-btn {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 48px; height: 48px; border-radius: 50%; background: var(--oro);
  display: flex; align-items: center; justify-content: center;
  transition: transform .2s; box-shadow: 0 4px 16px rgba(0,0,0,.4);
}
.play-btn .mi { color: var(--verde); font-size: 24px; margin-left: 2px; }
.video-thumb:hover .play-btn { transform: translate(-50%,-50%) scale(1.12); }
.vt-caption  { position: absolute; bottom: 0; left: 0; right: 0; padding: 8px 10px; }
.vt-title    { font-size: 12px; font-weight: 700; color: white; line-height: 1.3; }
.vt-dur      { font-size: 10px; color: var(--oro2); margin-top: 2px; }

/* Modal video */
.vid-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.9); z-index: 400;
  display: none; align-items: center; justify-content: center; padding: 20px;
}
.vid-modal-overlay.open { display: flex; }
.vid-modal { background: #0d1f15; border-radius: 12px; overflow: hidden; width: 100%; max-width: 760px; position: relative; }
.vid-modal-close {
  position: absolute; top: 10px; right: 10px; z-index: 5;
  background: rgba(0,0,0,.6); border: none; color: white;
  width: 34px; height: 34px; border-radius: 50%; font-size: 18px; cursor: pointer;
}
.vid-modal-title { padding: 14px 18px; background: var(--verde); font-size: 14px; font-weight: 700; color: white; }
.vid-modal-title span { font-size: 11px; color: var(--oro2); display: block; margin-top: 2px; }
.vid-container { position: relative; padding-bottom: 56.25%; background: #000; }
.vid-container iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.vid-placeholder {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; color: rgba(255,255,255,.4); font-size: 14px; gap: 12px;
}
.vid-placeholder .mi { font-size: 48px; opacity: .3; color: white; }

/* ── capacitacion.css ─────────────────── */
.cap-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); gap: 14px; }

.cap-card {
  background: #1e1e1e; border-radius: 10px; overflow: hidden; cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  border: 1px solid rgba(255,255,255,.06);
}
.cap-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.4); }

.cap-card-thumb { position: relative; aspect-ratio: 16/9; overflow: hidden; background: #0d2b1e; }
.cap-card-thumb img { width: 100%; height: 100%; object-fit: cover; opacity: .8; transition: opacity .2s; }
.cap-card:hover .cap-card-thumb img { opacity: 1; }
.cap-thumb-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 60%); }

.cap-badge {
  position: absolute; top: 8px; left: 8px;
  background: var(--oro); color: var(--verde);
  font-size: 9px; font-weight: 700; padding: 2px 8px;
  border-radius: 3px; letter-spacing: .5px; text-transform: uppercase;
}
.cap-live { background: #e53935; color: white; }
.cap-dur {
  position: absolute; bottom: 6px; right: 8px;
  background: rgba(0,0,0,.7); color: white; font-size: 10px; font-weight: 600;
  padding: 2px 6px; border-radius: 3px;
}
.cap-card-body { padding: 12px 14px 14px; display: flex; gap: 10px; }
.cap-canal-icon {
  width: 34px; height: 34px; flex-shrink: 0; border-radius: 50%;
  background: var(--verde3); display: flex; align-items: center; justify-content: center;
}
.cap-canal-icon .mi { font-size: 18px; color: white; }
.cap-info { flex: 1; min-width: 0; }
.cap-titulo {
  font-size: 13px; font-weight: 700; color: white; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; margin-bottom: 4px;
}
.cap-meta { font-size: 11px; color: #888; display: flex; align-items: center; gap: 6px; }
.cap-meta .mi { font-size: 13px; color: #666; }
.cap-actions { display: flex; align-items: center; gap: 6px; margin-top: 8px; }
.cap-action-btn {
  background: rgba(255,255,255,.07); border: none; color: #aaa;
  padding: 5px 10px; border-radius: 4px; font-size: 11px; font-weight: 600;
  display: flex; align-items: center; gap: 4px; transition: .15s; cursor: pointer;
}
.cap-action-btn .mi { font-size: 14px; }
.cap-action-btn:hover { background: rgba(255,255,255,.12); color: white; }