/* ====== RESET E BASE ====== */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Inter", "Segoe UI", Roboto, Arial, sans-serif;
  background: #f4f6f8;
  color: #333;
  line-height: 1.6;
}

/* ====== CONTAINER ====== */
.container {
  max-width: 80%;
  margin: 40px auto;
  background: #fff;
  padding: 32px;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  transition: all 0.3s ease;
}

/* ===================================
   Estilos para Mensagens de Feedback
   =================================== */

/* Estilo Base para todas as mensagens */
/* AUMENTO DE ESPECIFICIDADE: Usa a classe principal 'container' */

.container .message {
    padding: 15px;
    margin-bottom: 20px;
    border: 1px solid transparent;
    border-radius: 4px;
    font-size: 1em;
    font-weight: bold;
}

.container .message.success {
    color: #155724 !important; /* Usar !important como último recurso, mas ajuda a diagnosticar */
    background-color: #d4edda !important;
    border-color: #c3e6cb !important;
}

.container .message.error {
    color: #721c24 !important;
    background-color: #f8d7da !important;
    border-color: #f5c6cb !important;
}


/* Adicione estas novas regras no final do seu 'style.css' */

/* -------------------------------- */
/* ESTILOS ESPECÍFICOS PARA FORMULÁRIOS DE CLIENTE (edit.php / create.php) */
/* -------------------------------- */

/* Regras para remover a borda e padding do fieldset no formulário do cliente */
.client-form fieldset {
    border: none !important; /* Usar !important para anular quaisquer regras padrão do browser */
    padding: 0;
    margin-bottom: 25px; 
}

/* Regras para estilizar o legend como um título limpo */
.client-form legend {
    /* Remove a borda que o browser pode aplicar e garante a largura automática */
    border: none !important; 
    width: auto;
    
    /* Estiliza o texto como um cabeçalho sublinhado */
    font-size: 1.25rem;
    font-weight: 600;
    color: #333;
    padding: 0 0 10px 0; 
    border-bottom: 1px solid #ddd; /* Linha de separação subtil */
    margin-bottom: 15px; 
}

/* Estilo para que o botão de submissão tenha a mesma aparência do botão 'Cancelar' */
.button-primary {
    /* Herda o estilo primário de .button */
    display: inline-block;
    padding: 10px 18px;
    background: linear-gradient(135deg, #007bff, #00a6fb);
    color: #fff;
    border: none;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease-in-out;
    cursor: pointer;
}

.button-primary:hover {
    background: linear-gradient(135deg, #0069d9, #0096eb);
    transform: translateY(-2px);
    box-shadow: 0 3px 8px rgba(0, 123, 255, 0.25);
}

.container:hover {
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.1);
}

/* ====== CABEÇALHO ====== */
header.site-header {
  background: linear-gradient(90deg, #007bff, #00b4d8);
  color: #fff;
  padding: 14px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-radius: 0 0 12px 12px;
  flex-wrap: wrap;
}

/* LOGO E TÍTULO */
header.site-header .logo-area {
  display: flex;
  align-items: center;
  gap: 12px;
}

header.site-header .logo-area img {
  height: 100px;
  width: auto;
  border-radius: 6px;
}

header.site-header .logo-area h1 {
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: 0.3px;
}

/* ====== MENU DE NAVEGAÇÃO ====== */
header.site-header nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

/* Cada link vira um "botão" individual */
header.site-header nav a {
  color: #fff;
  background: rgba(2, 59, 66);
  text-decoration: none;
  font-weight: 500;
  padding: 8px 14px;
  border-radius: 8px;
  transition: all 0.25s ease;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
  display: inline-block;
}

header.site-header nav a:hover {
  background: #fff;
  color: #007bff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 123, 255, 0.25);
}

header.site-header nav a:active {
  transform: scale(0.96);
}

header.site-header nav a.logout {
  background: #ff4d4f;
  color: #fff;
}

header.site-header nav a.logout:hover {
  background: #ff2d2f;
  color: #fff;
  box-shadow: 0 4px 12px rgba(255, 77, 79, 0.35);
}

/* ====== TABELAS ====== */
.list {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
  border-radius: 8px;
  overflow: hidden;
}

.list th {
  background: #007bff;
  color: #fff;
  text-align: left;
  padding: 12px;
  font-weight: 600;
}

.list td {
  border-bottom: 1px solid #e0e0e0;
  padding: 12px;
}

.list tr:hover {
  background-color: #f8faff;
}

/* ====== BOTÕES PADRÃO ====== */
.button {
  display: inline-block;
  padding: 10px 18px;
  background: linear-gradient(135deg, #007bff, #00a6fb);
  color: #fff;
  border: none;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 500;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.button:hover {
  background: linear-gradient(135deg, #0069d9, #0096eb);
  transform: translateY(-2px);
  box-shadow: 0 3px 8px rgba(0, 123, 255, 0.25);
}

/* ====== FORMULÁRIOS ====== */
label {
  display: block;
  margin: 0px 0 6px;
  font-weight: 500;
}

input,
textarea,
select {
  width: 100%;
  padding: 10px 10px;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 0.9em;
  transition: border-color 0.2s ease;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: #007bff;
  box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.15);
}

/* ====== MENSAGENS DE ERRO ====== */
.error {
  background: #ffeaea;
  border-left: 4px solid #ff6b6b;
  color: #a94442;
  padding: 12px 16px;
  margin: 16px 0;
  border-radius: 6px;
}

/* ====== FOOTER ====== */
footer {
  text-align: center;
  color: #666;
  padding: 16px 0;
  font-size: 0.9rem;
}

/* ====== RESPONSIVIDADE ====== */
@media (max-width: 768px) {
  header.site-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  header.site-header nav {
    flex-wrap: wrap;
    gap: 8px;
  }

  header.site-header nav a {
    width: 100%;
    text-align: center;
  }

  .container {
    padding: 20px;
    margin: 20px;
  }

  .button {
    width: 100%;
    text-align: center;
  }

  /* Estilos gerais para a navegação - Adapte ao seu layout */
.site-header nav {
    /* Por exemplo, se for um menu horizontal */
    display: flex;
    list-style: none; /* Remove marcadores de lista */
    padding: 0;
    margin: 0;
}

/* Garante que os <li> e <a> se comportem como itens de menu */
.site-header nav > a, 
.site-header nav > li {
    padding: 10px 15px;
    text-decoration: none;
    /* Outros estilos de link/item... */
}

/* Estilos para o Item com Dropdown (menu-dropdown) */
.menu-dropdown {
    position: relative; /* Essencial para o sub-menu */
    display: inline-block; /* Ou flex, dependendo do seu layout */
}

/* Estilos para o Sub-menu (invisível por padrão) */
.submenu {
    display: none; /* Esconde o sub-menu por padrão */
    position: absolute; 
    top: 100%; /* Posiciona abaixo do item pai */
    left: 0;
    z-index: 10; /* Garante que fique acima de outros elementos */
    background-color: #333; /* Cor de fundo do sub-menu */
    min-width: 150px;
    list-style: none;
    padding: 0;
    margin: 0;

}

/* Estilos dos itens do Sub-menu */
.submenu li a {
    display: block;
    padding: 10px 15px;
    text-decoration: none;
    color: white; /* Cor dos links do sub-menu */
}

/* Estilo para mostrar o sub-menu ao passar o mouse */
.menu-dropdown:hover .submenu {
    display: block; /* Torna o sub-menu visível */
}

/* Estilos de hover nos links do sub-menu (opcional) */
.submenu li a:hover {
    background-color: #555;
}

}

/* Estilo para o formulário de filtros */
.filter-form {
    background-color: #f0f4f7; /* Cor de fundo suave */
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 15px;
    border: 1px solid #cceeff;
    display: flex;
    gap: 5px; /* Espaçamento entre os campos */
    flex-wrap: wrap; 
    align-items: flex-end; /* Alinha os itens na parte inferior */
    font-size: 0.9em;
}

.filter-form > div {
    flex-grow: 1; /* Permite que os campos cresçam para preencher o espaço */
    min-width: 150px;
}

.filter-form label {
    font-weight: 600;
    color: #333;
    margin-bottom: 5px;
    display: block;
    font-size: 0.9em;
}

/* Estilo para o agrupamento por Cliente */
.relatorio-cliente-group {
    margin-top: 40px;
    padding: 30px 0;
    border-top: 2px solid #0056b3; /* Linha divisória de cor primária */
}

.relatorio-cliente-group h3 {
    color: #0056b3;
    margin-bottom: 15px;
    padding-bottom: 5px;
    border-bottom: 1px dashed #ccc;
}

/* Estilo para as caixas de resumo financeiro */
.summary-box {
    background-color: #e9f7e9; /* Fundo verde claro para destaque */
    padding: 15px;
    border: 1px solid #c3e6cb;
    border-radius: 6px;
    margin-bottom: 20px;
    display: flex;
    justify-content: space-around;
    font-weight: bold;
    color: #216d21;
}

.summary-box span {
    flex: 1;
    text-align: center;
    border-right: 1px solid #c3e6cb;
}
.summary-box span:last-child {
    border-right: none;
}

/* Estilos de Status (O essencial para o visual) */
.status-previsto {
    color: #007bff; /* Azul primário */
    font-weight: 600;
    background-color: #eaf3ff;
    padding: 3px 8px;
    border-radius: 4px;
}

.status-pago {
    color: #28a745; /* Verde sucesso */
    font-weight: 600;
    background-color: #e5ffe8;
    padding: 3px 8px;
    border-radius: 4px;
}

.status-atrasado {
    color: #dc3545; /* Vermelho perigo */
    font-weight: bold;
    background-color: #ffe8e8;
    padding: 3px 8px;
    border-radius: 4px;
    border: 1px solid #dc3545;
}

.status-cancelado {
    color: #6c757d; /* Cinza desativado */
    text-decoration: line-through;
    font-style: italic;
    background-color: #f8f9fa;
    padding: 3px 8px;
    border-radius: 4px;
}

