.main-layout-video {
  display: flex;
  flex-direction: column;
  min-height: 100dvh; }

body {
  height: 100dvh;
  display: flex;
  flex-direction: column;
  padding-bottom: var(--footer-height);
  box-sizing: border-box; }

body > main {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  box-sizing: border-box; }
  @media (max-width: 994px) {
    body > main {
      overflow-x: hidden;
      overflow-y: auto; } }
body > .navbar {
  position: sticky;
  top: 0;
  width: 100%;
  z-index: 1001; }

body > .footer {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  min-width: 100vw;
  z-index: 1000; }

.pagina-clase {
  --page-nav-height: 67px;
  --page-header-height: 48px;
  --player-info-peek: 117px;
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
  width: 100%;
  overflow-x: hidden;
  background-color: var(--color-secondary); }
  @media (min-width: 1100px) {
    .pagina-clase {
      --page-nav-height: var(--nav-height); } }
  .pagina-clase .unidad-curricular {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 48px;
    padding: 0 16px;
    min-width: 0;
    overflow: hidden;
    box-sizing: border-box;
    background-color: var(--color-secondary); }
    .pagina-clase .unidad-curricular h1 {
      display: block;
      margin: 0;
      padding: 0;
      width: 100%;
      max-width: 100%;
      flex: 1 1 0;
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap; }
  .pagina-clase .distribucion-curso {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
    min-width: 0;
    width: 100%;
    background-color: var(--color-secondary); }
    @media (max-width: 994px) {
      .pagina-clase .distribucion-curso {
        flex: 0 0 auto;
        flex-direction: column;
        align-items: stretch;
        overflow: visible; }
        .pagina-clase .distribucion-curso > .detalle-clase {
          order: 0;
          width: 100%;
          min-width: 0;
          flex: 0 0 auto;
          overflow: visible; }
        .pagina-clase .distribucion-curso > .barra-lateral-curso {
          order: 1;
          width: 100%;
          min-width: 0;
          flex: 0 0 auto; } }
    @media (min-width: 995px) {
      .pagina-clase .distribucion-curso {
        flex-direction: row;
        align-items: stretch; } }
    .pagina-clase .distribucion-curso > .barra-lateral-curso {
      width: 100%;
      max-width: 100%;
      flex: 0 0 auto;
      border-right: 0;
      border-bottom: 1px solid var(--color-border);
      min-height: 0;
      min-width: 0; }
      @media (min-width: 995px) {
        .pagina-clase .distribucion-curso > .barra-lateral-curso {
          width: 379px;
          border-right: 1px solid var(--color-border);
          border-bottom: 0; } }
    .pagina-clase .distribucion-curso > .detalle-clase {
      display: flex;
      flex: 1 1 auto;
      flex-direction: column;
      width: 100%;
      max-width: 100%;
      min-width: 0;
      min-height: 0;
      overflow: auto; }
  .pagina-clase .barra-lateral-curso {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-width: 0;
    background-color: var(--color-secondary); }
    @media (max-width: 994px) {
      .pagina-clase .barra-lateral-curso {
        overflow: visible; } }
  .pagina-clase .lista-cursos {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-start;
    width: 100%;
    min-width: 0;
    padding: 12px 16px;
    box-sizing: border-box;
    border-bottom: 1px solid var(--color-border);
    font-size: 14px;
    font-weight: 500;
    line-height: normal; }
    .pagina-clase .lista-cursos .curso-enlace {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      max-width: 100%;
      padding: 10px;
      border-radius: 24px;
      background-color: var(--color-secondary-dark);
      color: var(--color-text);
      text-decoration: none;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      box-sizing: border-box;
      margin: 0rem; }
      .pagina-clase .lista-cursos .curso-enlace-activo {
        background-color: var(--color-primary);
        color: var(--color-secondary); }
  .pagina-clase .lista-clases {
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
    width: 100%;
    overflow-y: auto;
    border: 0; }
    @media (max-width: 994px) {
      .pagina-clase .lista-clases {
        flex: 0 0 auto;
        overflow: visible; } }
    .pagina-clase .lista-clases .clase-item {
      width: 100%;
      gap: 16px;
      padding: 16px;
      box-sizing: border-box; }
    .pagina-clase .lista-clases .clase-numero {
      width: 16px;
      min-width: 16px;
      text-align: left;
      font-weight: 400; }
    .pagina-clase .lista-clases .clase-titulo {
      flex: 1 1 auto;
      min-width: 0;
      padding: 0; }
  .pagina-clase .contenido-clase {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
    width: 100%; }
  .pagina-clase .player-section {
    --player-max-height: min(560px, 64sdvh);
    display: flex;
    justify-content: center;
    align-items: stretch;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    flex-shrink: 0;
    aspect-ratio: 16 / 9;
    height: auto;
    max-height: var(--player-max-height);
    overflow: hidden;
    background-color: black; }
    @media (min-width: 995px) {
      .pagina-clase .player-section {
        --player-max-height: calc(
                100dvh - var(--page-nav-height) - var(--footer-height) - var(--page-header-height) - var(--player-info-peek)
            ); } }
    .pagina-clase .player-section > * {
      flex: 1 1 auto;
      width: 100%;
      max-width: 100%;
      height: 100%;
      min-width: 0;
      min-height: 0; }
  .pagina-clase .video__youtube {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
    margin: 0; }
  .pagina-clase .video__player {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100% !important;
    overflow: hidden;
    background-color: black; }
    .pagina-clase .video__player > video[slot="media"] {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: contain;
      margin: 0 auto; }
  .pagina-clase .info-clase {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
    width: 100%;
    padding: 8px 0 16px;
    background-color: var(--color-secondary); }

.video__container {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
  width: 100%;
  overflow: scroll;
  scrollbar-width: none; }
  .video__container::-webkit-scrollbar {
    display: none; }
  @media (min-width: 995px) {
    .video__container {
      flex-direction: row;
      align-items: stretch; } }
.barra-lateral-curso {
  border-right: 1px solid var(--color-border);
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
  width: 100%;
  box-sizing: border-box; }

.lista-cursos {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  min-width: 0;
  padding: 12px 12px 0px; }
  .lista-cursos .curso-enlace {
    display: block;
    max-width: 100%;
    text-decoration: none;
    color: var(--color-text);
    font-size: 14px;
    margin-right: 10px;
    margin-bottom: 10px;
    border-radius: 20px;
    padding-left: 10px;
    padding-right: 10px;
    height: 35px;
    line-height: 35px;
    background-color: var(--color-secondary-dark);
    overflow: hidden;
    text-overflow: ellipsis; }
    .lista-cursos .curso-enlace-activo {
      background-color: var(--color-primary);
      color: var(--color-secondary); }

.lista-clases {
  display: flex;
  flex-flow: column nowrap;
  min-width: 0;
  width: 100%;
  overflow-y: scroll;
  -ms-overflow-style: none;
  /* IE and Edge */ }
  @media (min-width: 995px) {
    .lista-clases {
      border-left: 1px solid var(--color-border);
      border-top: 1px solid var(--color-border);
      border-bottom: 1px solid var(--color-border); } }
  .lista-clases .clase-enlace {
    display: block;
    width: 100%;
    min-width: 0;
    text-decoration: none;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border); }
    .lista-clases .clase-enlace:hover {
      background-color: var(--color-secondary-dark); }
  .lista-clases .clase-item {
    display: flex;
    flex-flow: row nowrap;
    width: 100%;
    box-sizing: border-box;
    min-width: 0;
    align-items: center; }
  .lista-clases .clase-item-activo {
    background-color: var(--color-primary);
    color: var(--color-secondary) !important; }
    .lista-clases .clase-item-activo:hover {
      background-color: var(--color-primary-dark) !important; }
  .lista-clases .clase-numero {
    font-weight: bold;
    width: 40px;
    text-align: center;
    flex-shrink: 0; }
  .lista-clases .clase-titulo {
    flex: 1 1 auto;
    min-width: 0;
    padding: 16px 10px;
    color: inherit;
    overflow: hidden;
    text-overflow: ellipsis; }

.video__player:fullscreen,
.video__player:-webkit-full-screen,
.video__player:-moz-full-screen,
.video__player[media-is-fullscreen] {
  width: 100% !important;
  max-width: none;
  max-height: none !important;
  height: 100% !important;
  aspect-ratio: auto; }

.titulo-clase {
  flex: 1 0 0;
  align-self: anchor-center;
  min-width: 200px;
  font-size: 24px;
  font-weight: 500;
  line-height: normal;
  margin: 0; }

.fecha-clase {
  display: block;
  font-size: 16px;
  margin: 0;
  font-style: normal;
  padding: 0;
  font-weight: 400;
  line-height: normal;
  color: var(--color-primary); }

.metadatos-clase {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  padding: 0 16px;
  box-sizing: border-box; }

.tarjeta-metadatos-clase {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 16px;
  width: 100%;
  padding: 12px 16px;
  border: 1px solid #eaeaea;
  border-radius: 21px;
  box-sizing: border-box; }

.tarjeta-metadatos-clase--colapsable {
  color: var(--color-primary);
  cursor: pointer; }
  .tarjeta-metadatos-clase--colapsable:not(.tarjeta-metadatos-clase--expandida):hover {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary-light); }
  .tarjeta-metadatos-clase--colapsable:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px; }

.tarjeta-metadatos-clase--expandida {
  color: inherit;
  cursor: default; }

.clase-metadata {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  width: 100%; }

.clase-metadata-resumen {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  color: var(--color-primary);
  font-size: 16px;
  font-weight: 400;
  line-height: normal;
  white-space: nowrap; }

.clase-metadata-accion {
  color: inherit; }

.clase-metadata-detalle {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  width: 100%; }

.clase-metadata-detalle[hidden] {
  display: none; }

.descripcion-clase {
  width: 100%;
  font-size: 16px;
  font-weight: 400;
  line-height: normal;
  color: var(--color-text); }
  .descripcion-clase p {
    margin: 0;
    white-space: pre-line; }

.docentes-clase {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  width: 100%;
  line-height: normal;
  color: var(--color-text); }

.docentes-clase-titulo {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
  line-height: normal; }

.docentes-clase-valor {
  margin: 0;
  min-width: 100%;
  font-size: 16px;
  font-weight: 400;
  line-height: normal; }

.institutos-clase {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  width: 100%;
  line-height: normal;
  color: var(--color-text); }

.institutos-clase-titulo {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
  line-height: normal; }

.institutos-clase-lista {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  width: 100%; }

.institutos-clase-valor {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  margin: 0;
  padding-block: 8px;
  padding-inline: 10px;
  border: 1px solid #eaeaea;
  border-radius: 999px;
  box-sizing: border-box;
  font-size: 16px;
  font-weight: 400;
  line-height: 1; }

.clase-metadata-ocultar {
  display: flex;
  align-items: center;
  width: 100%; }

.clase-metadata-ocultar[hidden] {
  display: none; }

.clase-metadata-ocultar-boton {
  padding: 0;
  border: none;
  background: none;
  color: var(--color-primary);
  font-family: inherit;
  font-size: 16px;
  font-weight: 400;
  font-synthesis: none;
  line-height: normal;
  text-align: left;
  cursor: pointer; }
  .clase-metadata-ocultar-boton:hover {
    font-weight: 700; }
  .clase-metadata-ocultar-boton:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    border-radius: 4px; }

.acciones-clase {
  display: flex;
  flex-wrap: wrap;
  flex-shrink: 0;
  align-items: flex-start;
  gap: 16px; }
  .acciones-clase a {
    text-decoration: none; }

.encabezado-clase {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  column-gap: 8px;
  row-gap: 8px;
  padding: 0 16px; }

.boton-accion-clase {
  display: inline-flex;
  justify-content: center;
  gap: 8px;
  padding: 10px;
  border: none;
  border-radius: 30px;
  background-color: var(--color-secondary);
  color: var(--color-text);
  cursor: pointer;
  font-family: inherit;
  font-size: 16px;
  font-weight: 400;
  line-height: normal;
  text-decoration: none;
  white-space: nowrap;
  box-sizing: border-box;
  appearance: none; }
  .boton-accion-clase:hover {
    background-color: var(--color-primary-light); }
  .boton-accion-clase:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px; }

.boton-accion-clase__icon {
  display: block;
  width: 20px;
  height: 20px;
  flex-shrink: 0; }

.boton-accion-clase__icon--compartir {
  width: 20px;
  height: 20px; }

.boton-accion-clase__icon--descargar {
  width: 19px;
  height: 20px; }

.dialog-container {
  display: grid;
  grid-template-areas: "header" "content";
  gap: 1.5rem; }

.share-header {
  grid-area: header;
  display: flex;
  width: 300px;
  align-items: center; }
  .share-header div {
    margin-left: 0;
    margin-right: auto;
    font-weight: bold; }
  .share-header span {
    cursor: pointer;
    margin-right: 0;
    margin-left: auto;
    font-size: 16px; }

.share-content {
  grid-area: content;
  display: flex;
  flex-direction: column;
  gap: 1rem; }
  .share-content .time-select {
    display: grid;
    grid-template-areas: "checkbox" "field";
    gap: .5rem; }
    .share-content .time-select label {
      grid-area: checkbox; }
    .share-content .time-select .time {
      grid-area: field;
      height: 30px; }
  .share-content .url {
    display: flex;
    flex-direction: row; }
    .share-content .url input {
      flex-grow: 1; }
    .share-content .url .url__icon {
      background-color: var(--color-primary);
      color: var(--color-secondary);
      border-radius: 0 5px 5px 0;
      flex-shrink: 0;
      display: flex;
      align-items: center;
      width: auto;
      height: 32px; }
      .share-content .url .url__icon svg {
        margin: 0 8px; }
      .share-content .url .url__icon:hover {
        cursor: pointer; }
