/* -------------------- GERAL DO SITE | FUNÇÃO: DEFINIÇÃO DE CORES PADRÃO E TAMANHO BASE -------------------- */
:root{

  --verde-escuro: #1b4332;
  --verde-musgo: #2d6a4f;
  --verde-claro: #40916c;

  --cinza: #6b7280;
  --branco: #ffffff;

  --container: 1100px;
}

/* -------------------- GERAL DO SITE | FUNÇÃO: RESET PADRÃO (REMOVE ESPAÇOS AUTOMÁTICOS) -------------------- */
*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

/* -------------------- GERAL DO SITE | ELEMENTO: BODY | FUNÇÃO: DEFINE FONTE E COR BASE -------------------- */
body{
  font-family: Arial, Helvetica, sans-serif;
  color:#e5dede;
}

/* -------------------- GERAL DO SITE | ELEMENTO: CONTAINER | FUNÇÃO: CENTRALIZAR CONTEÚDO -------------------- */
.container{
  width: min(var(--container), 90%);
  margin:auto;
}

/* -------------------- TODAS AS PÁGINAS | SEÇÃO: HEADER | FUNÇÃO: COR DE FUNDO DO CABEÇALHO -------------------- */
.header{
  background:rgb(37, 36, 36);
}

/* -------------------- TODAS AS PÁGINAS | SEÇÃO: HEADER | FUNÇÃO: ALINHAR LOGO E MENU -------------------- */
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px 0;
}

/* -------------------- TODAS AS PÁGINAS | ELEMENTO: LOGO | FUNÇÃO: ALINHAR ÍCONE E TEXTO -------------------- */
.logo{
  display:flex;
  align-items:center;
  font-weight:bold;
}

/* -------------------- TODAS AS PÁGINAS | ELEMENTO: ÍCONE DA LOGO -------------------- */
.logo-icon{
  width:30px;
  height:30px;
  background:var(--verde-musgo);
  border-radius:10px;
}

/* -------------------- TODAS AS PÁGINAS | ELEMENTO: IMAGEM DA LOGO -------------------- */
.logo-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* -------------------- TODAS AS PÁGINAS | ELEMENTO: MENU -------------------- */
nav a{
  margin-left:30px;
  font-weight:600;
  color:#e8e2e2;
  text-decoration:none;
}

/* ------------------- INDEX | ELEMENTO: FOTOS ANIMADAS DEMONSTRAÇÃO | ESTILO TAMANHO ---------------- */
.features-orbit {
  --box-size: 420px;
  --item-size: 100px;

  position: relative;
  width: var(--box-size);
  height: var(--box-size);
  margin: auto;
}

.orbit-item {
  position: absolute;
  top: 50%;
  left: 50%;
  width: var(--item-size);
  height: var(--item-size);
  border-radius: 10%;
  background: rgb(58, 56, 56);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  z-index: 2;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.orbit-item img {
  width: 110%;
  height: 100%;
  object-fit: contain;
  padding: 10px;
}

/* -------------------- TODAS AS PÁGINAS | SEÇÃO: HERO (TOPO DAS PÁGINAS) -------------------- */
.hero{
  background:linear-gradient(135deg,var(--verde-escuro),var(--verde-musgo));
  color:white;
  padding:120px 0;
  text-align:center;
}

.hero h1{
  font-size:48px;
  margin-bottom:20px;
}

.hero p{
  max-width:600px;
  margin:auto;
  margin-bottom:30px;
}

/* -------------------- TODAS AS PÁGINAS | BOTÕES -------------------- */
.btn{
  display:inline-block;
  background:rgb(37, 36, 36);
  color:var(--branco);
  padding:14px 28px;
  border-radius:6px;
  font-weight:bold;
  border:none;
  cursor:pointer;
}

/* -------------------- PÁGINA INICIAL | CARDS DE SERVIÇOS -------------------- */
.features{
  padding:80px 0;
  background:rgb(37, 36, 36);
}

.features-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
}

.features-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.feature-card{
  background:rgb(45, 44, 44);
  padding:25px;
  border-radius:8px;
}

/* -------------------- TODAS AS PÁGINAS | SEÇÃO: CONTATO FINAL | FUNÇÃO: ESTILIZAR A FAIXA VERDE ESCURA DO FINAL DAS PÁGINAS -------------------- */
.dark-section{
  background:var(--verde-escuro);
  color:rgb(214, 210, 210);
  padding:80px 0;
  text-align:center;
}

/* -------------------- TODAS AS PÁGINAS | ELEMENTO: TÍTULO DA ÁREA DE CONTATO FINAL | FUNÇÃO: TAMANHO E ESPAÇAMENTO DO H2 -------------------- */
.dark-section h2{
  font-size:36px;
  margin-bottom:20px;
}

/* -------------------- TODAS AS PÁGINAS | ELEMENTO: TEXTO DA ÁREA DE CONTATO FINAL | FUNÇÃO: LIMITAR LARGURA E SUAVIZAR O TEXTO -------------------- */
.dark-section p{
  max-width:600px;
  margin:auto;
  opacity:.9;
}

/* -------------------- TODAS AS PÁGINAS | RODAPÉ -------------------- */
.footer{
  padding:30px 0;
  text-align:center;
  background:rgb(37, 36, 36);
}

/* -------------------- PÁGINA: TICKETS | SEÇÃO: ÁREA PRINCIPAL DE CHAMADOS | FUNÇÃO: FUNDO E ESPAÇAMENTO DA PÁGINA -------------------- */
.tickets-page {
  background: rgb(37, 36, 36);
  color: var(--branco);
  padding: 80px 0;
}

/* -------------------- PÁGINA: TICKETS | ELEMENTO: CABEÇALHO DOS CHAMADOS | FUNÇÃO: CENTRALIZAR O TÍTULO -------------------- */
.tickets-header {
  text-align: center;
  margin-bottom: 50px;
}

.tickets-header h1 {
  font-size: 38px;
  margin-bottom: 10px;
}

/* -------------------- PÁGINA: TICKETS | SEÇÃO: PAINEL DE GRÁFICOS | FUNÇÃO: CAIXA PRINCIPAL DOS INDICADORES -------------------- */
.tickets-dashboard {
  background: rgb(45, 44, 44);
  border: 2px solid var(--verde-claro);
  border-radius: 12px;
  padding: 40px 30px;
  margin-bottom: 50px;
}

.tickets-dashboard h2 {
  text-align: center;
  margin-bottom: 35px;
  font-size: 28px;
}

/* -------------------- PÁGINA: TICKETS | SEÇÃO: GRID DOS INDICADORES | FUNÇÃO: DISTRIBUIR OS 3 CARDS LADO A LADO -------------------- */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  align-items: end;
  margin-bottom: 40px;
}

/* -------------------- PÁGINA: TICKETS | ELEMENTO: CARD DE STATUS | FUNÇÃO: ESTILO DE CADA BLOCO DE INDICADOR -------------------- */
.stat-card {
  text-align: center;
  background: rgb(58, 56, 56);
  border-radius: 10px;
  padding: 20px;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: center;
}

/* -------------------- PÁGINA: TICKETS | ELEMENTO: BARRA VISUAL DOS INDICADORES | FUNÇÃO: DESENHAR AS COLUNAS DOS GRÁFICOS -------------------- */
.stat-bar {
  width: 60px;
  background: var(--verde-claro);
  border-radius: 8px 8px 0 0;
  margin-bottom: 20px;
}

.bar-closed {
  height: 140px;
}

.bar-pending {
  height: 90px;
}

.bar-waiting {
  height: 40px;
}

/* -------------------- PÁGINA: TICKETS | ELEMENTO: TEXTO DOS CARDS | FUNÇÃO: TAMANHO E COR DOS RÓTULOS -------------------- */
.stat-card p {
  font-size: 24px;
  font-weight: bold;
  color: var(--branco);
}

/* -------------------- PÁGINA: TICKETS | ELEMENTO: BOTÃO NOVO CHAMADO | FUNÇÃO: CENTRALIZAR O BOTÃO ABAIXO DOS GRÁFICOS -------------------- */
.tickets-action {
  text-align: center;
}

.tickets-action .btn {
  background: var(--verde-musgo);
  padding: 16px 32px;
  border-radius: 8px;
  color: var(--branco);
  text-decoration: none;
  font-weight: bold;
  transition: 0.3s;
  border: none;
  cursor: pointer;
}

.tickets-action .btn:hover {
  background: var(--verde-claro);
}

/* -------------------- PÁGINA: TICKETS | ELEMENTO: TÍTULO DA ÁREA DE CHAMADOS ABERTOS | FUNÇÃO: CENTRALIZAR O SUBTÍTULO -------------------- */
.tickets-open h2 {
  text-align: center;
  margin-bottom: 30px;
  font-size: 30px;
}

/* -------------------- PÁGINA: TICKETS | SEÇÃO: FILTROS | FUNÇÃO: ORGANIZAR OS 3 CAMPOS DE PESQUISA -------------------- */
.tickets-filters {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 25px;
}

.tickets-filters input {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--cinza);
  border-radius: 8px;
  outline: none;
  background: rgb(58, 56, 56);
  color: var(--branco);
}

.tickets-filters input::placeholder {
  color: #cfcfcf;
}

/* -------------------- PÁGINA: TICKETS | SEÇÃO: TABELA DE CHAMADOS | FUNÇÃO: EVITAR QUEBRA EM TELAS MENORES -------------------- */
.tickets-table {
  overflow-x: auto;
}

.tickets-table table {
  width: 100%;
  border-collapse: collapse;
  background: rgb(45, 44, 44);
  border-radius: 10px;
  overflow: hidden;
}

.tickets-table th,
.tickets-table td {
  border: 1px solid rgb(70, 70, 70);
  padding: 18px;
  text-align: left;
}

.tickets-table th {
  background: var(--verde-escuro);
  color: var(--branco);
}

.tickets-table td {
  color: #e5dede;
}

/* -------------------- MODAL (POPUPS LOGIN E CHAMADO) -------------------- */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none;
  justify-content: center;
  align-items: center;
  background: rgba(0, 0, 0, 0.65);
  z-index: 9999;
}

/* -------------------- CONTEÚDO DO MODAL -------------------- */
.modal-content {
  width: min(700px, 92%);
  background: rgb(45, 44, 44);
  border-radius: 12px;
  padding: 28px;
}

/* -------------------- CAMPOS DO MODAL -------------------- */
.modal-content input,
.modal-content textarea,
.modal-content select {
  width: 100%;
  padding: 12px;
  margin-bottom:10px;
  border-radius:8px;
  background:rgb(58,56,56);
  color:white;
}

/* -------------------- BOTÃO DO MODAL -------------------- */
.modal-content button {
  background: var(--verde-musgo);
  padding: 12px;
  border-radius: 8px;
}

/* -------------------- TEXTO DE AJUDA DO LOGIN -------------------- */
.login-ajuda {
  margin-top: 15px;
  text-align: center;
}

.login-ajuda a {
  color: var(--verde-claro);
}