/* Importação da biblioteca Font Awesome para ícones */
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.1/css/all.min.css');
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;700&display=swap');

/* Variáveis de cores - tema madeira/aço */
:root {
    --cor-principal:#fff;
    --cor-secundaria:#8b5e3c;
    --cor-hover-button:#4f5b66;
    --cor-borda-tabela: #ccc;
    --cor-cabecalho-fundo: #ffffff;
    --cor-cabecalho-texto: #000000;
    --cor-linha-pares: #f9f9f9;
    --cor-linha-impares: #ffffff;
    --cor-hover-linha: #ecf0f1;
    --cor-texto: #7d8995;
    --cor-hover-texto: #55595d;
}

/* Reset básico e configuração global */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Nunito', sans-serif;
}

/* Estilos gerais da página */
body {
    min-height: 100vh;
    background-color: var(--cor-principal);
}
th, td {
    padding: 12px;
    border: 1px solid var(--cor-borda-tabela);
    text-align: left;
    color: var(--cor-texto);
}

/* Estilos para o cabeçalho */
th {
    background-color: var(--cor-cabecalho-fundo);
    color: var(--cor-cabecalho-texto);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* Estilos do conteúdo principal */
.content {
    padding: 30px;
    flex-grow: 1;
}

h1 {
    color: var(--cor-secundaria);
    margin-bottom: 20px;
}

/* Animação de fade-in para o conteúdo principal */
.content {
    animation: fadeIn 1s;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* Estilos dos botões com efeito hover */
button {
    background-color: var(--cor-secundaria);
    color: var(--cor-principal);
    border: 1px;
    border-radius: 10px;
    padding: 10px 20px;
    cursor: pointer;
    transition: background-color 0.3s;
    margin: 20px;
}

button:hover {
    background-color: var(--cor-hover-button);
}

/* Estilos gerais para tabelas */
table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 20px;
    font-family: 'Arial', sans-serif;
}

/* Linhas alternadas */
tr:nth-child(even) {
    background-color: var(--cor-linha-pares);
}

tr:nth-child(odd) {
    background-color: var(--cor-linha-impares);
}

/* Efeito de hover para linhas */
tr:hover {
    background-color: var(--cor-hover-linha);
    color: var(--cor-hover-texto);
}

/* Estilos responsivos */
@media screen and (max-width: 768px) {
    table, thead, tbody, th, td, tr {
        display: block;
    }

    th, td {
        padding: 10px;
    }

    thead tr {
        display: none;
    }

    tr {
        margin-bottom: 10px;
    }

    td {
        text-align: right;
        position: relative;
        padding-left: 50%;
    }

    td:before {
        content: attr(data-label);
        position: absolute;
        left: 10px;
        width: calc(50% - 20px);
        padding-right: 10px;
        text-align: left;
        font-weight: bold;
    }
}
.btn-primary {
    background-color: var(--cor-secundaria);
    color: var(--cor-principal);
    border: 20px;
    margin: 20px;
    padding: 10px 20px;
    border-radius: 5px;
    text-decoration: none;
    font-size: 16px;
    display: inline-block;
}

.btn-primary:hover {
    background-color: var(--cor-hover-texto);
}

.content-also{
    position: fixed;
    left: 0;
    top: 0;
    width: 400px;
    height: 100%;
    background-color: var(--cor-principal);
    z-index: 1000;
    overflow: hidden;
    transition: width 0.5s;
}

.login-header {
    background-color: var(--cor-principal);
    color: var(--cor-borda-tabela);
    text-align: center;
}

.input-group {
    padding: 20px;
    background-color: var(--cor-principal);
    color: var(--cor-borda-tabela);
}

.select, select {
    margin-top: 20px;
    width: 300px; /* Largura do input box */
    height: 40px; /* Altura do input box */
    padding: 10px; /* Espaçamento interno */
    border-radius: 10px; /* Cantos arredondados */
    border: 1px solid var(--cor-borda-tabela); /* Bordas */
    font-size: 16px; /* Tamanho da fonte */
}

input[type="text"], input[type="password"], input[type="email"], input[type="number"], textarea {
    margin-top: 20px;
    width: 300px; /* Largura do input box */
    height: 40px; /* Altura do input box */
    padding: 10px; /* Espaçamento interno */
    border-radius: 10px; /* Cantos arredondados */
    border: 1px solid var(--cor-borda-tabela); /* Bordas */
    font-size: 16px; /* Tamanho da fonte */
}

input[type="text"]:focus, input[type="password"]:focus, input[type="email"]:focus, input[type="number"]:focus, textarea:focus {
    margin-top: 20px;
    outline: none; /* Remove o outline padrão ao focar */
    border-color: var(--cor-secundaria); /* Cor da borda ao focar */
    box-shadow: 0 0 5px rgba(139, 94, 60, 0.5); /* Sombra ao focar */
}

input[type="date"] {
    margin-top: 20px;
    width: 150px; /* Largura do input box */
    height: 40px; /* Altura do input box */
    padding: 10px; /* Espaçamento interno */
    border-radius: 10px; /* Cantos arredondados */
    border: 1px solid var(--cor-borda-tabela); /* Bordas */
    font-size: 16px; /* Tamanho da fonte */
}

input[type="date"]:focus{
    margin-top: 20px;
    outline: none; /* Remove o outline padrão ao focar */
    border-color: var(--cor-secundaria); /* Cor da borda ao focar */
    box-shadow: 0 0 5px rgba(139, 94, 60, 0.5); /* Sombra ao focar */
}

.responsive-image {
    max-width: 90%;
    height: auto;
    border: 0px solid var(--cor-borda-tabela);
    border-radius: 10px;
}

.card {
    background-color: var(--cor-principal);
    padding: 20px;
    margin: 10px 0;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.card h2 {
    margin-top: 0;
}

.card-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 10px;
}

.card-table th, .card-table td {
    padding: 8px 12px;
    border: 1px solid var(--cor-borda-tabela);
    text-align: left;
}
.card-table th {
    background-color: var(--cor-principal);
}

.container {
    position: relative;
    width: 70%;
    bottom: 0;
    margin: auto;
    padding: 20px;
}

textarea {
    width: 100%;
    height: 50%;
    box-sizing: border-box;
    display: block;
    margin-top: 10px;
}

.card-container {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.action-icons a {
    margin-right: 10px;
}

/* Badges de status (orçamentos, pedidos, cobranças) */
.badge {
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: bold;
    display: inline-block;
    white-space: nowrap;
}

.badge-pendente, .badge-aberto {
    background-color: #fff3cd;
    color: #856404;
}

.badge-aprovado, .badge-pago, .badge-concluido, .badge-entregue {
    background-color: #d4edda;
    color: #155724;
}

.badge-recusado, .badge-cancelado, .badge-vencido {
    background-color: #f8d7da;
    color: #721c24;
}

.badge-convertido, .badge-em_producao, .badge-entrada {
    background-color: #d1ecf1;
    color: #0c5460;
}

.badge-saida {
    background-color: #e2d4f0;
    color: #4a235a;
}

/* Destaque para itens com estoque abaixo do mínimo */
.estoque-baixo {
    color: #c0392b;
    font-weight: bold;
}

/* Cards de indicadores do dashboard */
.dashboard-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 20px;
}

.dashboard-card {
    flex: 1;
    min-width: 200px;
    background-color: var(--cor-principal);
    border-radius: 10px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    padding: 20px;
    border-left: 5px solid var(--cor-secundaria);
}

.dashboard-card h3 {
    color: var(--cor-texto);
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 10px;
}

.dashboard-card .valor {
    color: var(--cor-secundaria);
    font-size: 32px;
    font-weight: bold;
}

.dashboard-card.alerta {
    border-left-color: #c0392b;
}

.dashboard-card.alerta .valor {
    color: #c0392b;
}

/* Tabela de itens do orçamento/pedido */
.itens-table input[type="text"],
.itens-table input[type="number"] {
    margin-top: 0;
    width: 100%;
    height: 36px;
}

.total-row td {
    font-weight: bold;
    color: var(--cor-cabecalho-texto);
}

/* Estilo da lista de menus */
.menu {
    list-style: none; /* Remover marcadores da lista */
    display: flex; /* Exibir itens em linha */
    flex-wrap: wrap; /* Permitir quebra de linha */
    flex-direction: column; /* Dispor itens em coluna */
    align-items: center; /* Centralizar itens horizontalmente */
    justify-content: space-around; /* Espaçar igualmente os itens */
    padding: 20px; /* Espaçamento interno */
    background-color: var(--cor-principal); /* Cor de fundo do menu */
}

/* Estilo dos itens do menu */
.menu .card-menu {
    width: 100%; /* Largura dos cards */
    margin-top: 10px; /* Espaçamento ao redor dos cards */
    background-color: var(--cor-principal); /* Cor de fundo dos cards */
    border-radius: 10px; /* Arredondamento dos cantos */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Sombra dos cards */
    overflow: hidden; /* Esconder qualquer conteúdo que ultrapasse os cards */
    transition: transform 0.3s ease; /* Transição suave para animações */
    text-align: left;
    padding: 20px;
}

/* Efeito de hover para os cards */
.menu .card-menu:hover {
    transform: scale(1.02); /* Aumentar o tamanho dos cards em 2% */
}

/* Estilo dos links dos cards */
.menu .card-menu a {
    text-decoration: none; /* Remover sublinhado dos links */
    color: var(--cor-secundaria); /* Cor dos links */
    font-size: 24px; /* Tamanho da fonte dos links */
    display: block; /* Exibir links como bloco */
    padding: 10px 0; /* Espaçamento interno dos links */
    transition: color 0.3s ease; /* Transição suave para a cor dos links */
}

/* Estilo das descricões dos cards */
.menu .card-menu p {
    color: var(--cor-hover-texto); /* Cor do texto */
    font-size: 16px; /* Tamanho da fonte dos links */
    padding: 10px 0; /* Espaçamento interno dos links */
    transition: color 0.3s ease; /* Transição suave para a cor dos links */
}

/* Efeito de hover para os links */
.menu .card-menu a:hover {
    color: var(--cor-hover-button); /* Cor dos links ao passar o mouse */
}

/* Estilo do cabeçalho */
.header {
    display: flex; /* Exibir itens em linha */
    justify-content: space-between; /* Espaçar itens nos extremos */
    align-items: center; /* Alinhar itens ao centro verticalmente */
    padding: 0px 25px; /* Espaçamento interno */
    background-color: var(--cor-secundaria); /* Cor de fundo do cabeçalho */
    color: var(--cor-principal); /* Cor do texto */
    height: 80px;
}

/* Estilo da seção esquerda do cabeçalho */
.header-left {
    display: flex; /* Exibir itens em linha */
    align-items: center; /* Alinhar itens ao centro verticalmente */
}

.site-name {
    font-size: 28px; /* Tamanho da fonte do nome do site */
    color: var(--cor-principal);
    font-weight: bold;
}

/* Estilo da seção direita do cabeçalho */
.header-right {
    display: flex; /* Exibir itens em linha */
    align-items: center; /* Alinhar itens ao centro verticalmente */
    padding: 30px;
}

.dropdown {
    position: relative; /* Posição relativa para o dropdown */
    display: inline-block; /* Exibição inline */
    margin-right: 10px; /* Espaçamento à direita do dropdown */
}

.dropdown-content {
    display: none; /* Esconder conteúdo por padrão */
    position: absolute; /* Posição absoluta para o conteúdo */
    right: 0;
    background-color: var(--cor-principal); /* Cor de fundo do conteúdo */
    min-width: 120px; /* Largura mínima do conteúdo */
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2); /* Sombra do conteúdo */
    z-index: 1; /* Garantir que o conteúdo fique acima de outros elementos */
    border-radius: 10px; /* Arredondamento dos cantos */
}

.dropdown-content a {
    color: black; /* Cor do texto */
    padding: 12px 16px; /* Espaçamento interno */
    text-decoration: none; /* Remover sublinhado dos links */
    display: block; /* Exibir links como bloco */
}

.dropdown-content a:hover {
    background-color: var(--cor-hover-linha); /* Cor de fundo ao passar o mouse */
}

.dropdown:hover .dropdown-content {
    display: block; /* Mostrar conteúdo ao passar o mouse */
    border-radius: 10px; /* Arredondamento dos cantos */
}

.header-right img {
    height: 60px;
    width: 60px;
    border-radius: 50%;
    border: 1px solid var(--cor-principal);
}

.breadcrumbs {
    display: flex; /* Exibir itens em linha */
    padding: 10px 20px; /* Espaçamento interno */
    margin-top: 10px; /* Espaçamento superior */
}

.breadcrumbs a::after {
    content: '>'; /* Separador entre as breadcrumbs */
    margin-left: 5px; /* Espaçamento à esquerda do separador */
}

.breadcrumbs a.breadcrumb-link, .breadcrumbs span.breadcrumb-link {
    color: var(--cor-secundaria); /* Cor dos links */
    font-size: 20px; /* Tamanho da fonte */
    text-decoration: none; /* Remover sublinhado dos links */
    padding: 0 5px; /* Espaçamento interno */
}

.breadcrumbs a.breadcrumb-link:hover {
    text-decoration: underline;
}

/* Estilo da apresentacao */
.welcome {
    display: flex; /* Exibir itens em linha */
    justify-content: space-between; /* Espaçar itens nos extremos */
    align-items: center; /* Alinhar itens ao centro verticalmente */
    color: var(--cor-hover-texto); /* Cor do texto */
    font-size: 26px; /* Tamanho da fonte */
    padding: 40px;
    background: linear-gradient(135deg, #f5efe8 0%, #e8edf0 100%);
}

/* Estilo da seção esquerda da apresentacao */
.welcome-left {
    display: flex; /* Exibir itens em linha */
    align-items: center; /* Alinhar itens ao centro verticalmente */
    padding: 30px;
    max-width: 60vw;
    min-width: 300px;
}

.menu #searchInput {
    margin: 10px 0;
    padding: 10px;
    width: 80%;
    border: 1px solid #ccc;
    border-radius: 10px;
}

.menu ul {
    width: 80%;
    display: flex;
    align-content: center;
    flex-direction: column;
    list-style: none;
}

/* Esconde elementos na impressão (botões, breadcrumbs, etc.) */
@media print {
    .no-print, .breadcrumbs {
        display: none !important;
    }
}
