/* =================================================================
   Habla — WATCH module
   ================================================================= */

.video-list {
  list-style: none;
  padding: 0;
  margin: 0 0 clamp(48px, 7vh, 80px);
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--rule);
}
.video-item {
  margin: 0;
  border-bottom: 1px solid var(--rule);
}
.video-item-button {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(44px, 56px) 1fr minmax(24px, auto);
  align-items: center;
  gap: clamp(16px, 2vw, 28px);
  padding: clamp(16px, 2vh, 22px) clamp(8px, 1vw, 16px);
  text-align: left;
  background: transparent;
  transition: background 180ms ease, color 180ms ease;
}
.video-item-button:hover, .video-item-button:focus-visible {
  background: var(--cielo-soft);
  outline: none;
}
.video-num {
  font-family: var(--font-mono);
  font-size: 0.92rem;
  letter-spacing: 0.14em;
  color: var(--cielo);
  font-weight: 600;
}
.video-meta-inline {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.video-theme {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--carbon-3);
}
.video-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: 'opsz' 96, 'wght' 600, 'WONK' 35;
  font-size: clamp(17px, 0.5vw + 12px, 22px);
  letter-spacing: -0.015em;
  color: var(--carbon);
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
}
.video-dur {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--carbon-3);
}
.video-arrow {
  font-size: 1.2rem;
  color: var(--carbon-3);
  transition: color 180ms ease, transform 240ms ease;
}
.video-item-button:hover .video-arrow {
  color: var(--cielo);
  transform: translateX(4px);
}

/* ============ Session ============ */

.video-session {
  padding-top: clamp(8px, 1vh, 16px);
  max-width: 100%;
}
.video-session .back {
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  margin-bottom: clamp(20px, 3vh, 30px);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--carbon-2);
}
.video-session .back:hover { color: var(--cielo); }

.video-embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--rule);
}
.video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.video-meta {
  margin-top: clamp(20px, 3vh, 28px);
  padding: clamp(20px, 3vh, 28px);
  border: 1px solid var(--rule);
  border-radius: var(--radius-md);
  background: var(--navy-2);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.video-session-slug {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--cielo);
}
.video-meta h3 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(20px, 1vw + 14px, 28px);
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--paper);
}
.video-session-stat {
  margin: 0;
  color: var(--paper-2);
  font-size: 0.95rem;
}
.video-session-stat .mono {
  font-family: var(--font-mono);
  color: var(--paper);
}
.video-meta .cta {
  align-self: flex-start;
  margin-top: 8px;
}
.video-done-hint {
  margin: 8px 0 0;
  color: var(--cielo);
  font-size: 0.92rem;
}
.video-meta .cta[disabled] {
  background: var(--paper-4);
  color: var(--paper-2);
  cursor: default;
}
.video-meta .cta[disabled]:hover { background: var(--paper-4); transform: none; }
