/* PDV Karaokê - Estilos CSS */

:root {
  /* Paleta de cores em tons de lilás - Modo Claro (padrão) */
  --cor-primaria: #8A4FFF; /* Lilás principal */
  --cor-secundaria: #B088FF; /* Lilás mais claro */
  --cor-terciaria: #673AB7; /* Lilás mais escuro */
  --cor-alerta: #FF5252; /* Vermelho para alertas */
  --cor-sucesso: #4CAF50; /* Verde para sucesso */
  --cor-warning: #FFC107; /* Amarelo para avisos */
  --cor-fundo: #F9F5FF; /* Fundo em tom muito claro de lilás */
  --cor-fundo-card: #fff; /* Fundo dos cards em branco */
  --cor-fundo-tabela: #fff; /* Fundo das tabelas */
  --cor-fundo-navbar: linear-gradient(135deg, var(--cor-primaria), var(--cor-terciaria)); /* Fundo da navbar */
  --cor-fundo-secao: rgba(138, 79, 255, 0.05); /* Fundo de seções ao passar o mouse */
  --cor-texto: #333; /* Cinza escuro para textos */
  --cor-texto-claro: #666; /* Cinza mais claro para textos secundários */
  --cor-branco: #fff; /* Branco puro */
  --cor-texto-navbar: rgba(255, 255, 255, 0.9); /* Texto da navbar */
  --cor-borda: #eee; /* Cor para bordas sutis */
  --sombra-suave: 0 2px 10px rgba(138, 79, 255, 0.1);
  --transicao-padrao: all 0.3s ease;
}

/* Tema Escuro */
[data-theme="dark"] {
  --cor-primaria: #9D67FF; /* Lilás principal mais claro */
  --cor-secundaria: #7E57C2; /* Lilás secundário ajustado */
  --cor-terciaria: #5E35B1; /* Lilás mais escuro ajustado */
  --cor-alerta: #FF5252; /* Vermelho para alertas (mantido) */
  --cor-sucesso: #4CAF50; /* Verde para sucesso (mantido) */
  --cor-warning: #FFC107; /* Amarelo para avisos (mantido) */
  --cor-fundo: #1A1625; /* Fundo escuro com tom de lilás */
  --cor-fundo-card: #2D2438; /* Fundo dos cards em tom escuro */
  --cor-fundo-tabela: #2D2438; /* Fundo das tabelas */
  --cor-fundo-navbar: linear-gradient(135deg, #5E35B1, #3D2A60); /* Fundo da navbar escuro */
  --cor-fundo-secao: rgba(157, 103, 255, 0.1); /* Fundo de seções ao passar o mouse */
  --cor-texto: #E1D9F3; /* Texto principal claro com tom lilás */
  --cor-texto-claro: #A99FC2; /* Texto secundário em tom mais claro */
  --cor-branco: #E1D9F3; /* "Branco" ajustado para o tema escuro */
  --cor-texto-navbar: rgba(255, 255, 255, 0.95); /* Texto da navbar */
  --cor-borda: #3D2A60; /* Cor para bordas no tema escuro */
  --sombra-suave: 0 2px 10px rgba(0, 0, 0, 0.3);
}

body {
  font-family: 'Poppins', 'Roboto', sans-serif;
  background-color: var(--cor-fundo);
  color: var(--cor-texto);
  margin: 0;
  padding: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Header e navegação */
.navbar {
  background: var(--cor-fundo-navbar);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  padding: 0.8rem 1rem;
  transition: background 0.3s ease;
}

.navbar-brand {
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  color: var(--cor-branco) !important;
  display: flex;
  align-items: center;
}

.navbar-brand svg {
  margin-right: 0.5rem;
}

.navbar-brand span {
  font-size: 1.4rem;
}

.navbar-nav .nav-link {
  color: var(--cor-texto-navbar) !important;
  font-weight: 500;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  transition: var(--transicao-padrao);
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
  background-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-2px);
}

.navbar-nav .nav-link i {
  margin-right: 6px;
}

/* Container principal */
.main-container {
  flex: 1;
  padding: 2rem;
  overflow-x: hidden;
}

/* Títulos */
.page-title {
  color: var(--cor-terciaria);
  font-weight: 700;
  margin-bottom: 1.5rem;
  border-bottom: 2px solid var(--cor-secundaria);
  padding-bottom: 0.5rem;
  display: inline-block;
}

/* Cards */
.card {
  border: none;
  border-radius: 10px;
  box-shadow: var(--sombra-suave);
  transition: var(--transicao-padrao);
  overflow: hidden;
  height: 100%;
  background-color: var(--cor-fundo-card);
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 15px rgba(138, 79, 255, 0.2);
}

.card-header {
  background-color: var(--cor-primaria);
  color: var(--cor-branco);
  font-weight: 600;
  padding: 1rem;
  border: none;
}

.card-body {
  padding: 1.5rem;
  color: var(--cor-texto);
}

/* Botões */
.btn-primary {
  background-color: var(--cor-primaria);
  border-color: var(--cor-primaria);
  transition: var(--transicao-padrao);
}

.btn-primary:hover {
  background-color: var(--cor-terciaria);
  border-color: var(--cor-terciaria);
  transform: translateY(-2px);
}

.btn-outline-primary {
  border-color: var(--cor-primaria);
  color: var(--cor-primaria);
}

.btn-outline-primary:hover {
  background-color: var(--cor-primaria);
  color: var(--cor-branco);
}

.btn-danger {
  background-color: var(--cor-alerta);
  border-color: var(--cor-alerta);
}

/* Alertas e notificações */
.alert-estoque {
  background-color: rgba(255, 193, 7, 0.15);
  border-left: 4px solid var(--cor-warning);
  padding: 0.8rem;
  border-radius: 4px;
  margin-bottom: 0.5rem;
}

.badge-estoque-baixo {
  background-color: var(--cor-alerta);
  color: var(--cor-branco);
  padding: 0.4rem 0.6rem;
  border-radius: 5px;
  font-weight: 500;
}

/* Caixas de estatísticas no dashboard */
.stats-box {
  background: var(--cor-branco);
  border-radius: 10px;
  padding: 1.2rem;
  box-shadow: var(--sombra-suave);
  text-align: center;
  transition: var(--transicao-padrao);
  height: 100%;
}

.stats-box:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 15px rgba(138, 79, 255, 0.2);
}

.stats-box .stats-value {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--cor-primaria);
  margin: 0.5rem 0;
}

.stats-box .stats-label {
  font-size: 1rem;
  color: var(--cor-texto);
  font-weight: 500;
}

.stats-box .stats-icon {
  color: var(--cor-secundaria);
  font-size: 2.5rem;
  margin-bottom: 0.8rem;
}

/* Tabelas */
.table {
  background-color: var(--cor-fundo-tabela);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--sombra-suave);
  color: var(--cor-texto);
}

.table thead {
  background-color: var(--cor-primaria);
  color: var(--cor-branco);
}

.table thead th {
  border: none;
  padding: 1rem;
  font-weight: 600;
}

.table tbody tr {
  transition: var(--transicao-padrao);
}

.table tbody tr:hover {
  background-color: var(--cor-fundo-secao);
}

.table td {
  border-color: var(--cor-borda);
}

.table-action {
  color: var(--cor-primaria);
  cursor: pointer;
  margin: 0 0.3rem;
  transition: var(--transicao-padrao);
}

.table-action:hover {
  color: var(--cor-terciaria);
  transform: scale(1.2);
}

/* Paginação */
.page-item.active .page-link {
  background-color: var(--cor-primaria);
  border-color: var(--cor-primaria);
}

.page-link {
  color: var(--cor-primaria);
}

/* Formulários */
.form-control:focus,
.form-select:focus {
  border-color: var(--cor-secundaria);
  box-shadow: 0 0 0 0.25rem rgba(138, 79, 255, 0.25);
}

.form-label {
  font-weight: 500;
  color: var(--cor-terciaria);
}

/* Elementos de vendas */
.carrinho-venda {
  background-color: var(--cor-branco);
  padding: 1.5rem;
  border-radius: 10px;
  box-shadow: var(--sombra-suave);
}

.item-venda {
  padding: 0.8rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.item-venda:last-child {
  border-bottom: none;
}

.total-venda {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--cor-primaria);
  text-align: right;
  padding: 1rem 0 0.5rem;
}

/* Elementos do dashboard */
.chart-container {
  background-color: var(--cor-branco);
  border-radius: 10px;
  padding: 1.5rem;
  box-shadow: var(--sombra-suave);
  height: 100%;
  min-height: 300px;
}

/* Footer */
footer {
  background-color: var(--cor-terciaria);
  color: var(--cor-branco);
  padding: 1.5rem 0;
  margin-top: auto;
  text-align: center;
}

/* Responsividade */
@media (max-width: 768px) {
  .main-container {
    padding: 1rem;
  }
  
  .stats-box .stats-value {
    font-size: 1.8rem;
  }
  
  .card-header {
    padding: 0.8rem;
  }
  
  .card-body {
    padding: 1rem;
  }
}

/* Botão de alternância de tema (Dark/Light mode) */
.btn-tema {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0.1);
  color: var(--cor-branco);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.2rem;
  transition: var(--transicao-padrao);
  border: none;
}

.btn-tema:hover {
  background-color: rgba(0, 0, 0, 0.2);
  transform: rotate(30deg);
}

.btn-tema i {
  transition: transform 0.5s ease;
}

[data-theme="dark"] .btn-tema .fa-moon {
  display: none;
}

[data-theme="dark"] .btn-tema .fa-sun {
  display: inline-block;
}

[data-theme="light"] .btn-tema .fa-sun {
  display: none;
}

[data-theme="light"] .btn-tema .fa-moon {
  display: inline-block;
}

/* Ajustes específicos para modo escuro */
[data-theme="dark"] .modal-content {
  background-color: var(--cor-fundo-card);
  color: var(--cor-texto);
}

[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background-color: rgba(61, 42, 96, 0.8);
  border-color: #5E35B1;
  color: var(--cor-texto);
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
  background-color: rgba(61, 42, 96, 0.9);
  color: var(--cor-branco);
  border-color: var(--cor-primaria);
}

[data-theme="dark"] .form-label {
  color: var(--cor-texto);
}

[data-theme="dark"] .text-muted {
  color: var(--cor-texto-claro) !important;
}

/* Animações e efeitos especiais para tema de karaokê */
@keyframes pulsar {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.05);
    opacity: 0.9;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.karaoke-theme {
  animation: pulsar 4s infinite;
}

.music-wave {
  position: relative;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.music-wave span {
  width: 3px;
  height: 100%;
  margin: 0 2px;
  background-color: var(--cor-secundaria);
  border-radius: 3px;
  animation: wave 1.5s infinite;
}

.music-wave span:nth-child(1) {
  animation-delay: 0.1s;
  height: 10px;
}

.music-wave span:nth-child(2) {
  animation-delay: 0.2s;
  height: 15px;
}

.music-wave span:nth-child(3) {
  animation-delay: 0.3s;
  height: 20px;
}

.music-wave span:nth-child(4) {
  animation-delay: 0.4s;
  height: 25px;
}

.music-wave span:nth-child(5) {
  animation-delay: 0.5s;
  height: 30px;
}

@keyframes wave {
  0% {
    height: 5px;
  }
  50% {
    height: 100%;
  }
  100% {
    height: 5px;
  }
}
