* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: Arial, sans-serif;
  display: flex;
  flex-direction: column;
  height: 100vh; /* Garantir que o body ocupe toda a altura da tela */
}

.container {
  display: flex;
  flex-grow: 1; /* O container vai ocupar o espaço restante */
  height: calc(100vh - 50px); /* Ajusta para que o conteúdo ocupe toda a altura menos o rodapé */
}

.sidebar {
  width: 20%;
  background-color: #f4f4f4;
  padding: 20px;
  box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);
  flex-shrink: 0;
  overflow-y: auto; /* Habilitar rolagem quando o conteúdo for maior que a altura da sidebar */
  height: 100%; /* Garantir que a sidebar ocupe toda a altura da tela */
}

.sidebar h2 {
  font-size: 18px;
  margin-top: 0;
}

.sidebar ul {
  list-style: none;
  padding: 0;
}

.sidebar li {
  margin: 15px 0;
}

.content {
  flex-grow: 1;
  padding: 0;
  height: 100%; /* Garantir que a área do iframe ocupe o restante da tela */
}

iframe {
  width: 100%;
  height: 100%;
  border: none;
}

a {
  text-decoration: none;
  color: #007bff;
}

a:hover {
  text-decoration: underline;
}

.aula-title {
  font-weight: bold;
  font-size: 16px;
}

.links {
  margin-top: 5px;
}

.no-link {
  color: #888;
  font-style: italic;
}

/* Rodapé ajustado para não sobrepor o conteúdo */
footer {
  width: 100%;
  background-color: #f4f4f4;
  padding: 10px;
  box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.1);
  text-align: center;
  margin-top: auto; /* Garante que o rodapé vá para a parte inferior */
}

.footer-content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.cc-logo {
  width: 4%;
  height: 4%;
  vertical-align: middle;
}

footer p {
  font-size: 14px;
  color: #333;
  margin: 0;
}
/* Responsividade para dispositivos móveis */
@media (max-width: 768px) {
  .container {
    flex-direction: column; /* Empilha o conteúdo (sidebar e iframe) em coluna */
  }

  .sidebar {
    width: 100%; /* Sidebar agora ocupa toda a largura na versão mobile */
    height: 45%; /* Sidebar ocupa no máximo 20% da altura da tela */
    padding: 10px;
    box-shadow: none; /* Remove a sombra para uma aparência mais limpa no mobile */
    position: relative;
    top: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; /* Ajusta os itens ao lado um do outro */
  }

  .sidebar li {
    margin-bottom: 10px;
  }

  .content {
    height: 80%; /* O iframe ocupa o restante da tela */
  }

  iframe {
    height: 100%;
  }

  footer {
    position: relative; /* Garante que o rodapé se mova para baixo quando necessário */
  }
}