/* ==================================================================
   Estilos Gerais e Reset
   ================================================================== */
   * {
    font-family: 'Roboto', sans-serif; /* Define a fonte padrão */
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Variáveis CSS para cores */
:root {
    --cor-fundo: hsla(0, 0%, 100%, .15);
    --cor-borda: #ddd;
    --cor-hover: #f4f4f4;
    --cor-texto: white;
    --cor-menu: #111;
}

/* ==================================================================
   Estilos para Telas Maiores (1024px e acima)
   ================================================================== */
@media only screen and (min-width: 1024px) {

    /* Corpo da Página */
    body {
        display: flex;
        flex-direction: column; /* Organiza os elementos na coluna */
        height: 100vh; /* Faz o body ocupar toda a altura da tela */
        background-color: #1A1A1A;
        line-height: 1.6;
    }

    /* Conteúdo principal (main) */
    main {
        flex: 1; /* Faz o conteúdo ocupar o espaço restante */
        padding: 20px;
    }

    /* Estilos para o Header e Logo */
    header {
        position: relative; /* Garante que o logo seja posicionado relativamente ao header */
        z-index: 100; /* Garante que o header fique acima de outros elementos */
    }

    .logo-title {
        position: absolute;
        top: 15px; /* Ajuste a distância do topo conforme necessário */
        left: 20px; /* Ajuste a distância da esquerda conforme necessário */
        z-index: 101; /* Garante que o logo fique acima do menu lateral */
    }

    .logo-title a {
        color: #979797;
        font: 550 26px / 60px DIN_Regular, Arial, Verdana, sans-serif;
        font-style: italic;
        text-decoration: none; /* Remove o sublinhado do link */
    }

    /* Título */
    .title-principal {
        font: 700 60px / 88px DIN_Regular, Arial, Verdana, sans-serif;
        color: #979797;
        text-align: center;
        margin: 10px 0;
    }

    /* Cabeçalho e Navbar */
    #navbar {
        display: flex;
        background-color: transparent;
        padding: 40px;
        justify-content: flex-end;
    }

    #menu-topo {
        margin-left: 25px;
        background-color: transparent;
        cursor: pointer;
        border: none;
        color: #979797;
    }

    /* Links no Navbar */
    #navbar a {
        font: 14px / 26px Roboto, Helvetica, sans-serif;
        padding: 0 20px;
        color: var(--cor-texto);
        text-decoration: none;
        transition: color 0.3s; /* Transição suave na cor do texto */
    }

    /* Menu Lateral (Barra Lateral) */
    #barra-lateral {
        height: 100%;
        width: 0;
        position: fixed;
        top: 0;
        right: 0;
        background-color: var(--cor-menu);
        overflow-x: hidden;
        transition: 0.5s;
        padding-top: 60px;
        box-shadow: 2px 0 5px rgba(0, 0, 0, 0.5);
        z-index: 999; /* Garante que o menu fique sobre outros conteúdos */
    }

    #barra-lateral a {
        display: flex;
        align-items: center;
        font-size: 14px;
        transition: width 0.5s ease, opacity 0.5s ease;
        border-bottom: 1px solid hsla(0, 0%, 100%, .16);
        padding: 20px 0;
        margin: 0;
        width: 100%;
        font-weight: bold;
    }

    #barra-lateral a:hover {
        color: #f1f1f1;
    }

    /* Caixa Interna da Barra Lateral */
    #caixa-interna-barra-lateral {
        padding: 20px;
    }

    /* Botão de Fechar (X) */
    #botao-x {
        position: absolute;
        top: 20px;
        left: 20px;
        font-size: 20px;
        color: var(--cor-texto);
        background-color: transparent;
        cursor: pointer;
        border: none;
    }

    /* Caixa Central */
    .navbar-central {
        margin-top: 10vh;
        align-items: center;
        display: flex;
        flex-direction: column;
        background-color: #202020;
        width: 50%;
        padding: 30px;
        margin-top: 5%;
        margin-left: 25%;
        border: 1px solid #383636;
        border-radius: 10px;
    }

    /* Botões e Vídeo */
    #videoElementId {
        color: var(--cor-texto);
        margin-bottom: 20px; /* Ajusta o espaçamento inferior */
        padding: 10px;
    }

    #extractBtn, #stopBtn {
        font: 14px / 20px Roboto, Helvetica, Arial, Verdana, sans-serif;
        color: white;
        border-radius: 4px;
        margin: 10px;
        margin-right: 25px;
        margin-left: 25px;
        background-color: #5952d6;
        width: 150px;
        height: 40px;
        border: 0px solid var(--cor-borda); /* Borda sutil */
        transition: background-color 0.3s; /* Transição suave na cor de fundo */
    }

    #extractBtn:hover, #stopBtn:hover {
        border: 1px solid #453ecc;
        cursor: pointer;
        background-color: #453ecc; /* Cor de fundo no hover */
    }

    .progress-container {
        margin-top: 50px; /* Ajusta o espaçamento superior */
        margin-bottom: 30px; /* Ajusta o espaçamento inferior */
    }

    #progressBar {
        height: 8px;
        width: 400px;
        background-color: #ddd; /* Cor de fundo do progress bar */
        border-radius: 12px; /* Bordas arredondadas */
        appearance: none; /* Remove o estilo padrão do navegador */
        -webkit-appearance: none; /* Remove o estilo no Safari */
        background-color: #e0e0e0; /* Cor de fundo da barra */
        transition: width 0.3s ease-in-out; /* Transição suave para mudanças */
    }

    /* Estilos para a parte preenchida da barra */
    progress::-webkit-progress-bar {
        background-color: #e0e0e0;
        border-radius: 12px;
    }

    progress::-webkit-progress-value {
        background-color: #4caf50; /* Cor verde para o progresso */
        border-radius: 12px;
    }

    progress::-moz-progress-bar {
        background-color: #4caf50;
        border-radius: 12px;
    }

    /* Animação para o texto da barra de progresso */
    @keyframes fadeIn {
        0% { opacity: 0; }
        100% { opacity: 1; }
    }

    /* Estilo para o texto da barra de progresso */
    .progress-text {
        font-size: 14px;
        font-weight: bold;
        margin-top: 10px;
        color: #979797;
        animation: fadeIn 1s ease-out;
    }

    #downBtn {
        font-size: 16px;
        color: white;
        border-radius: 4px;
        background-color: #5952d6;
        width: 250px;
        height: 50px;
        border: 0px solid var(--cor-borda); /* Borda sutil */
        transition: background-color 0.3s; /* Transição suave na cor de fundo */
    }

    #downBtn:hover {
        border: 1px solid black;
        cursor: pointer;
        background-color: #453ecc; /* Cor de fundo no hover */
    }

    /*Notificação tipo roast para substituir o alert*/
    .notification {
        position: fixed; /* Fixa no topo da tela */
        top: 20px; /* Distância do topo da tela */
        left: 50%; /* Centraliza horizontalmente */
        transform: translateX(-50%); /* Ajusta para que a notificação esteja centralizada */
        background-color: #4CAF50; /* Cor de fundo verde para sucesso */
        color: white;
        padding: 10px 20px;
        border-radius: 5px;
        display: none; /* Inicialmente invisível */
        z-index: 1000;
        font-size: 16px;
        text-align: center; /* Centraliza o texto dentro da notificação */
        opacity: 0; /* Inicialmente invisível */
        transition: opacity 3s ease, transform 3s ease; /* Transição suave para opacidade e movimento */
        width: auto; /* Largura adaptável ao texto */
        max-width: 80%; /* Limita a largura máxima da notificação */
    }
    
    .notification.show {
        opacity: 1; /* Torna a notificação visível */
        transform: translateX(-50%) translateY(0); /* Centraliza e remove o deslocamento */
        display: block; /* Torna o display visível para que a transição ocorra */
    }

    /* Classe para notificação de sucesso (verde) */
    .notification.success {
        background-color: #4CAF50;
    }

    /* Classe para notificação de erro (vermelha) */
    .notification.error {
        background-color: #f44336;
    }
    /* Footer */
    footer {
        color: #979797;
        text-align: center;
        padding-top: 10px;
    }

    footer ul {
        list-style: none;
        padding: 0;
    }

    footer ul li {
        display: inline;
        margin: 0 10px;
    }

    footer ul li a {
        color: #979797;
        text-decoration: none;
    }

    footer ul li a:hover {
        text-decoration: underline;
    }
}


/* ==================================================================
   Estilos para Telas Menores (500px e abaixo)
   ================================================================== */
@media only screen and (max-width: 500px) {

    /* Corpo da Página */
    body {
        display: flex;
        flex-direction: column; /* Organiza os elementos na coluna */
        height: 100vh; /* Faz o body ocupar toda a altura da tela */
        background-color: #1A1A1A;
        line-height: 1.6;
    }

     /* Conteúdo principal (main) */
     main {
        flex: 1; /* Faz o conteúdo ocupar o espaço restante */
        padding: 10px;
        margin-top: 50px;
    }

    /* Título */
    .title-principal {
        font: 700 24px / 32px DIN_Regular, Arial, Verdana, sans-serif;
        color: #979797;
        text-align: center;
        display: flex;
        margin: 30px;
    }

    /* Cabeçalho e Navbar */
    #navbar {
        display: flex;
        background-color: transparent;
        justify-content: right;
        padding: 10px;
    }

    #menu-topo {
        margin: 10px;
        background-color: transparent;
        cursor: pointer;
        border: none;
        color: var(--cor-texto);
    }

    /* Barra Lateral */
    .sidenav {
        height: 100%;
        width: 0;
        position: fixed;
        top: 0;
        right: 0;
        background-color: rgba(0, 0, 0, 0.9);
        overflow-x: hidden;
        transition: 0.5s;
        padding-top: 60px;
        z-index: 999; /* Garante que a barra lateral esteja acima do conteúdo */
    }

    #barra-lateral a {
        display: flex;
        color: white;
        align-items: center;
        font-size: 14px;
        transition: width 0.5s ease, opacity 0.5s ease;
        border-bottom: 1px solid hsla(0, 0%, 100%, .16);
        padding: 20px;
        margin: 0;
        width: 100%;
        font-weight: bold;
        text-decoration: none;
    }

    #barra-lateral a:hover {
        color: #f1f1f1;
    }

    /* Botão de Fechar (X) */
    #botao-x {
        position: absolute;
        top: 15px;
        left: 10px;
        font-size: 20px;
        color: var(--cor-texto);
        background-color: transparent;
        cursor: pointer;
        border: none;
    }

    /* Caixa Central */
    .navbar-central {
        width: 80%;
        margin-left: 5%;
        position: relative; /* Garantir que não se sobreponha ao menu lateral */
        top: 30%;
        transform: translateY(-50%);
        background-color: #202020;
        padding: 20px;
        z-index: 1; /* Garante que o conteúdo esteja acima do menu lateral */
        flex-direction: column;
        padding: 30px;
        margin-top: 5%;
        border: 1px solid #383636;
        border-radius: 10px;
    }

    /* Botões e Vídeo */
    #videoElementId {
        margin-top: 20px;
        margin-bottom: 20px;
        color: var(--cor-texto);
    }

    #extractBtn, #stopBtn {
        width: 100%;
        height: 40px;
        font: 14px / 20px Roboto, Helvetica, Arial, Verdana, sans-serif;
        background-color: #5952d6;
        color: white;
        border-radius: 4px;
        margin: 10px 0;
        font-size: 16px;
        border: 0px solid var(--cor-borda); /* Borda sutil */
        transition: background-color 0.3s; /* Transição suave na cor de fundo */
    }

    #extractBtn:hover, #stopBtn:hover {
        border: 1px solid black;
        cursor: pointer;
        background-color: #7A6FD6;
    }

    #downBtn {
        width: 100%;
        height: 50px;
        color: white;
        border-radius: 4px;
        margin-top: 20px;
        font-size: 16px;
        background-color: #5952d6;
        border: 0px solid var(--cor-borda); /* Borda sutil */
        transition: background-color 0.3s; /* Transição suave na cor de fundo */
    }

    #downBtn:hover {
        border: 1px solid black;
        cursor: pointer;
        background-color: #453ecc; /* Cor de fundo no hover */
    }

    /*Notificação tipo roast para substituir o alert*/
    .notification {
        position: fixed; /* Fixa no topo da tela */
        top: 20px; /* Distância do topo da tela */
        left: 50%; /* Centraliza horizontalmente */
        transform: translateX(-50%); /* Ajusta para que a notificação esteja centralizada */
        background-color: #4CAF50; /* Cor de fundo verde para sucesso */
        color: white;
        padding: 10px 20px;
        border-radius: 5px;
        display: none; /* Inicialmente invisível */
        z-index: 1000;
        font-size: 16px;
        text-align: center; /* Centraliza o texto dentro da notificação */
        opacity: 0; /* Inicialmente invisível */
        transition: opacity 3s ease, transform 3s ease; /* Transição suave para opacidade e movimento */
        width: auto; /* Largura adaptável ao texto */
        max-width: 80%; /* Limita a largura máxima da notificação */
    }
    
    .notification.show {
        opacity: 1; /* Torna a notificação visível */
        transform: translateX(-50%) translateY(0); /* Centraliza e remove o deslocamento */
        display: block; /* Torna o display visível para que a transição ocorra */
    }

    /* Classe para notificação de sucesso (verde) */
    .notification.success {
        background-color: #4CAF50;
    }

    /* Classe para notificação de erro (vermelha) */
    .notification.error {
        background-color: #f44336;
    }

    /* Estilo para o contêiner da barra de progresso */
    .progress-container {
        margin-top: 25px; /* Ajusta o espaçamento superior */
        margin-bottom: 15px; /* Ajusta o espaçamento inferior */
    }

    /* Estilizando a barra de progresso */
    #progressBar {
        height: 8px;
        width: 100%;
        background-color: #ddd; /* Cor de fundo do progress bar */
        border-radius: 12px; /* Bordas arredondadas */
        appearance: none; /* Remove o estilo padrão do navegador */
        -webkit-appearance: none; /* Remove o estilo no Safari */
        background-color: #e0e0e0; /* Cor de fundo da barra */
        transition: width 0.3s ease-in-out; /* Transição suave para mudanças */
    }

    /* Estilos para a parte preenchida da barra */
    progress::-webkit-progress-bar {
        background-color: #e0e0e0;
        border-radius: 12px;
    }

    progress::-webkit-progress-value {
        background-color: #4caf50; /* Cor verde para o progresso */
        border-radius: 12px;
    }

    progress::-moz-progress-bar {
        background-color: #4caf50;
        border-radius: 12px;
    }

    /* Footer */
    footer {
        background-color: #1A1A1A;
        color: #979797;
        padding: 10px;
        text-align: center;
    }
    
    footer ul {
        list-style: none;
        padding: 0;
    }
    
    footer ul li {
        display: inline;
        margin: 0 10px;
    }

    footer ul li a {
        color: #979797;
        text-decoration: none;
    }
    
    footer ul li a:hover {
        text-decoration: underline;
   }
}