/* Sistema de Tema Moderno para Opanel */
/* Arquivo: css/modern-theme.css */

:root {
  /* Light Mode Variables */
  --light-bg-primary: #ffffff;
  --light-bg-secondary: #f8f9fa;
  --light-bg-tertiary: #e9ecef;
  --light-bg-card: #ffffff;
  --light-bg-sidebar: #2c3e50;
  --light-bg-navbar: #ffffff;
  --light-text-primary: #2c3e50;
  --light-text-secondary: #6c757d;
  --light-text-muted: #adb5bd;
  --light-border: #dee2e6;
  --light-accent-gold: #d4af37;
  --light-accent-gold-hover: #b8941f;
  --light-accent-gold-light: #f4e6a0;
  --light-shadow: rgba(0, 0, 0, 0.1);
  --light-shadow-hover: rgba(0, 0, 0, 0.15);

  /* Dark Mode Variables */
  --dark-bg-primary: #1a1a1a;
  --dark-bg-secondary: #2d2d2d;
  --dark-bg-tertiary: #404040;
  --dark-bg-card: #2d2d2d;
  --dark-bg-sidebar: #1a1a1a;
  --dark-bg-navbar: #2d2d2d;
  --dark-text-primary: #ffffff;
  --dark-text-secondary: #b3b3b3;
  --dark-text-muted: #808080;
  --dark-border: #404040;
  --dark-accent-gold: #d4af37;
  --dark-accent-gold-hover: #b8941f;
  --dark-accent-gold-light: #4a3f1f;
  --dark-shadow: rgba(0, 0, 0, 0.3);
  --dark-shadow-hover: rgba(0, 0, 0, 0.4);

  /* Gradientes */
  --gradient-gold: linear-gradient(135deg, #d4af37 0%, #b8941f 100%);
  --gradient-gold-light: linear-gradient(135deg, #f4e6a0 0%, #d4af37 100%);
  --gradient-dark: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%);
  --gradient-card: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%);

  /* Sombras modernas */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-gold: 0 4px 20px rgba(212, 175, 55, 0.3);

  /* Transições */
  --transition-fast: 0.15s ease-in-out;
  --transition-normal: 0.3s ease-in-out;
  --transition-slow: 0.5s ease-in-out;

  /* Border radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* Espaçamentos */
  --spacing-xs: 0.25rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1rem;
  --spacing-lg: 1.5rem;
  --spacing-xl: 2rem;
  --spacing-2xl: 3rem;
}

/* Light Mode (default) */
body:not(.dark-mode) {
  --bg-primary: var(--light-bg-primary);
  --bg-secondary: var(--light-bg-secondary);
  --bg-tertiary: var(--light-bg-tertiary);
  --bg-card: var(--light-bg-card);
  --bg-sidebar: var(--light-bg-sidebar);
  --bg-navbar: var(--light-bg-navbar);
  --text-primary: var(--light-text-primary);
  --text-secondary: var(--light-text-secondary);
  --text-muted: var(--light-text-muted);
  --border-color: var(--light-border);
  --accent-gold: var(--light-accent-gold);
  --accent-gold-hover: var(--light-accent-gold-hover);
  --accent-gold-light: var(--light-accent-gold-light);
  --shadow: var(--light-shadow);
  --shadow-hover: var(--light-shadow-hover);
}

/* Dark Mode */
body.dark-mode {
  --bg-primary: var(--dark-bg-primary);
  --bg-secondary: var(--dark-bg-secondary);
  --bg-tertiary: var(--dark-bg-tertiary);
  --bg-card: var(--dark-bg-card);
  --bg-sidebar: var(--dark-bg-sidebar);
  --bg-navbar: var(--dark-bg-navbar);
  --text-primary: var(--dark-text-primary);
  --text-secondary: var(--dark-text-secondary);
  --text-muted: var(--dark-text-muted);
  --border-color: var(--dark-border);
  --accent-gold: var(--dark-accent-gold);
  --accent-gold-hover: var(--dark-accent-gold-hover);
  --accent-gold-light: var(--dark-accent-gold-light);
  --shadow: var(--dark-shadow);
  --shadow-hover: var(--dark-shadow-hover);
}

/* Estilos Gerais Modernos */
/* Correção para evitar múltiplas barras de rolagem */
html, body {
  overflow-x: visible !important;
  height: 100% !important;
}

/* MOBILE: Permitir scroll horizontal nas tabelas */
@media (max-width: 992px) {
  html, body {
    overflow-x: visible !important;
    overflow-y: auto !important;
  }
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  background-color: var(--bg-primary) !important;
  color: var(--text-primary) !important;
  transition: background-color var(--transition-normal), color var(--transition-normal) !important;
}

/* Remover possíveis conflitos de scrollbar */
.sidebar {
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

.main-sidebar .sidebar {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  height: 100% !important;
}

/* Modern Navbar */
.main-header.navbar {
  background: var(--bg-navbar) !important;
  border-bottom: 1px solid var(--border-color) !important;
  box-shadow: var(--shadow-sm) !important;
  backdrop-filter: blur(10px) !important;
}

.main-header .nav-link {
  color: var(--text-secondary) !important;
  transition: color var(--transition-fast) !important;
}

.main-header .nav-link:hover {
  color: var(--accent-gold) !important;
}

.main-header .btn-primary {
  background: var(--gradient-gold) !important;
  border: none !important;
  color: #000 !important;
  font-weight: 600 !important;
  border-radius: var(--radius-md) !important;
  transition: all var(--transition-fast) !important;
  box-shadow: var(--shadow-md) !important;
}

.main-header .btn-primary:hover {
  background: var(--accent-gold-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* Modern Sidebar */
.main-sidebar {
  background: var(--bg-sidebar) !important;
  box-shadow: var(--shadow-lg) !important;
}

.brand-link {
  border-bottom: 1px solid var(--border-color) !important;
  background: linear-gradient(135deg, var(--bg-sidebar) 0%, var(--accent-gold-light) 100%) !important;
}

.user-panel {
  border-bottom: 1px solid var(--border-color) !important;
}

.user-panel .info .d-block {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
}

.nav-sidebar .nav-item .nav-link {
  color: var(--text-secondary) !important;
  transition: all var(--transition-fast) !important;
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0 !important;
  margin: var(--spacing-xs) var(--spacing-sm) !important;
}

.nav-sidebar .nav-item > .nav-link.active,
.nav-sidebar .nav-item.menu-open > .nav-link {
  background: var(--gradient-gold) !important;
  color: #000 !important;
  box-shadow: var(--shadow-md) !important;
}

.nav-sidebar .nav-item:hover > .nav-link {
  background: var(--bg-tertiary) !important;
  color: var(--accent-gold) !important;
}

.nav-header {
  color: var(--accent-gold) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.05em !important;
}

/* Modern Cards - Enhanced */
.card {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-md) !important;
  transition: all var(--transition-normal) cubic-bezier(0.4, 0, 0.2, 1) !important;
  overflow: hidden !important;
  position: relative !important;
}

.card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background: var(--gradient-gold) !important;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0 !important;
}

.card:hover {
  box-shadow: var(--shadow-xl) !important;
  transform: translateY(-4px) scale(1.02) !important;
  border-color: var(--accent-gold-light) !important;
}

.card-header {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%) !important;
  border-bottom: 1px solid var(--border-color) !important;
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0 !important;
  padding: var(--spacing-lg) !important;
}

.card-title {
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  color: var(--text-primary) !important;
  margin-bottom: var(--spacing-md) !important;
  display: flex !important;
  align-items: center !important;
  gap: var(--spacing-sm) !important;
}

.card-title i {
  color: var(--accent-gold) !important;
}

/* Modern Info Boxes - Enhanced */
.info-box {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 5px solid var(--accent-gold) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  transition: all var(--transition-normal) cubic-bezier(0.4, 0, 0.2, 1) !important;
  overflow: hidden !important;
  position: relative !important;
}

.info-box::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 100% !important;
  background: linear-gradient(135deg, transparent 0%, rgba(212, 175, 55, 0.05) 50%, transparent 100%) !important;
  pointer-events: none !important;
}

.info-box:hover {
  box-shadow: var(--shadow-xl) !important;
  transform: translateY(-2px) scale(1.02) !important;
  border-left-color: var(--accent-gold-hover) !important;
}

.info-box .info-box-icon {
  background: var(--gradient-gold-light) !important;
  color: var(--accent-gold) !important;
  border-radius: var(--radius-lg) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 70px !important;
  height: 70px !important;
  font-size: 1.75rem !important;
  box-shadow: var(--shadow-md) !important;
}

.info-box .info-box-content {
  padding: var(--spacing-lg) !important;
}

.info-box .info-box-text {
  font-size: 0.875rem !important;
  margin-bottom: var(--spacing-xs) !important;
  color: var(--text-secondary) !important;
  font-weight: 500 !important;
}

.info-box .info-box-number {
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  line-height: 1 !important;
}

/* Modern Tables - Enhanced */
.table {
  background: var(--bg-card) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-md) !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

.table thead th {
  background: var(--gradient-gold) !important;
  color: #000 !important;
  font-weight: 600 !important;
  border: none !important;
  text-transform: uppercase !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.05em !important;
  padding: var(--spacing-lg) var(--spacing-md) !important;
  position: relative !important;
}

.table thead th:first-child {
  border-radius: var(--radius-lg) 0 0 0 !important;
}

.table thead th:last-child {
  border-radius: 0 var(--radius-lg) 0 0 !important;
}

.table tbody tr {
  transition: all var(--transition-fast) ease !important;
  border: none !important;
}

.table tbody tr:last-child td:first-child {
  border-radius: 0 0 0 var(--radius-lg) !important;
}

.table tbody tr:last-child td:last-child {
  border-radius: 0 0 var(--radius-lg) 0 !important;
}

.table td {
  border-color: var(--border-color) !important;
  transition: all var(--transition-fast) ease !important;
  padding: var(--spacing-lg) var(--spacing-md) !important;
  vertical-align: middle !important;
}

.table-hover tbody tr:hover {
  background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(212, 175, 55, 0.05) 100%) !important;
  color: var(--accent-gold) !important;
  transform: scale(1.01) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05) !important;
}

/* Modern Buttons - Enhanced */
.btn {
  border-radius: var(--radius-lg) !important;
  font-weight: 600 !important;
  transition: all var(--transition-normal) cubic-bezier(0.4, 0, 0.2, 1) !important;
  border: 2px solid transparent !important;
  box-shadow: var(--shadow-sm) !important;
  position: relative !important;
  overflow: hidden !important;
  text-transform: none !important;
  letter-spacing: 0.025em !important;
}

.btn::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent) !important;
  transition: left 0.6s ease !important;
}

.btn:hover::before {
  left: 100% !important;
}

.btn-primary {
  background: var(--gradient-gold) !important;
  color: #000 !important;
  border-color: var(--accent-gold) !important;
  box-shadow: var(--shadow-gold) !important;
}

.btn-primary:hover {
  background: linear-gradient(135deg, var(--accent-gold-hover) 0%, #d4af37 100%) !important;
  transform: translateY(-2px) scale(1.05) !important;
  box-shadow: 0 8px 25px rgba(212, 175, 55, 0.4) !important;
  border-color: var(--accent-gold-hover) !important;
}

.btn-secondary {
  background: transparent !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
  position: relative !important;
  z-index: 1 !important;
}

.btn-secondary::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 0 !important;
  height: 100% !important;
  background: var(--gradient-gold) !important;
  transition: width var(--transition-normal) ease !important;
  z-index: -1 !important;
  border-radius: var(--radius-lg) !important;
}

.btn-secondary:hover::before {
  width: 100% !important;
}

.btn-secondary:hover {
  color: #000 !important;
  border-color: var(--accent-gold) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-md) !important;
}

/* Modern Form Controls - Enhanced */
.form-control {
  border-radius: var(--radius-lg) !important;
  border: 2px solid var(--border-color) !important;
  transition: all var(--transition-normal) cubic-bezier(0.4, 0, 0.2, 1) !important;
  background: var(--bg-card) !important;
  color: var(--text-primary) !important;
  padding: var(--spacing-sm) var(--spacing-md) !important;
  font-size: 0.875rem !important;
  line-height: 1.5 !important;
}

.form-control:focus {
  border-color: var(--accent-gold) !important;
  box-shadow: 0 0 0 0.2rem rgba(212, 175, 55, 0.25) !important;
  background: var(--bg-card) !important;
  transform: scale(1.02) !important;
}

.form-control:hover {
  border-color: var(--accent-gold-light) !important;
}

/* Modern Select2 - Enhanced */
.select2-container--default .select2-selection--single {
  border-radius: var(--radius-lg) !important;
  border: 2px solid var(--border-color) !important;
  height: auto !important;
  background: var(--bg-card) !important;
  transition: all var(--transition-normal) ease !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--text-primary) !important;
  padding: var(--spacing-sm) var(--spacing-md) !important;
  line-height: 1.5 !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%) !important;
  right: var(--spacing-md) !important;
}

.select2-dropdown {
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border-color) !important;
  box-shadow: var(--shadow-xl) !important;
  overflow: hidden !important;
}

.select2-results__option {
  padding: var(--spacing-sm) var(--spacing-md) !important;
  transition: all var(--transition-fast) ease !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background: var(--gradient-gold-light) !important;
  color: #000 !important;
}

/* Modern Navbar - Enhanced */
.main-header.navbar {
  background: linear-gradient(135deg, var(--bg-navbar) 0%, var(--bg-secondary) 100%) !important;
  border-bottom: 1px solid var(--border-color) !important;
  box-shadow: var(--shadow-lg) !important;
  backdrop-filter: blur(10px) !important;
}

/* Modern Sidebar - Enhanced */
.main-sidebar {
  background: linear-gradient(135deg, var(--bg-sidebar) 0%, var(--bg-tertiary) 100%) !important;
  box-shadow: var(--shadow-xl) !important;
  position: relative !important;
  overflow: hidden !important;
}

.main-sidebar::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 4px !important;
  height: 100% !important;
  background: var(--gradient-gold) !important;
  border-radius: 0 2px 2px 0 !important;
}

.brand-link {
  border-bottom: 1px solid var(--border-color) !important;
  background: linear-gradient(135deg, var(--bg-sidebar) 0%, var(--accent-gold-light) 100%) !important;
  position: relative !important;
  overflow: hidden !important;
}

.brand-link::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(212, 175, 55, 0.1), transparent) !important;
  animation: shimmer 3s infinite !important;
}

.brand-link .brand-image {
  box-shadow: var(--shadow-md) !important;
  border-radius: var(--radius-md) !important;
  transition: all var(--transition-normal) ease !important;
}

.brand-link:hover .brand-image {
  transform: scale(1.1) !important;
  box-shadow: var(--shadow-lg) !important;
}

.user-panel {
  border-bottom: 1px solid var(--border-color) !important;
  background: linear-gradient(135deg, var(--bg-sidebar) 0%, var(--bg-tertiary) 100%) !important;
  position: relative !important;
}

.user-panel::before {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: var(--gradient-gold) !important;
}

.user-panel .info .d-block {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
}

.nav-sidebar .nav-item {
  position: relative !important;
  margin: var(--spacing-xs) 0 !important;
}

/* Correção para links do sidebar */
.nav-sidebar .nav-link {
  color: var(--text-secondary) !important;
  transition: all var(--transition-normal) cubic-bezier(0.4, 0, 0.2, 1) !important;
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0 !important;
  margin: 0 var(--spacing-sm) !important;
  padding: var(--spacing-sm) var(--spacing-lg) !important;
  position: relative !important;
  overflow: hidden !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  display: block !important;
  cursor: pointer !important;
}

.nav-sidebar .nav-link::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 0 !important;
  height: 100% !important;
  background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(212, 175, 55, 0.05) 100%) !important;
  transition: width var(--transition-normal) ease !important;
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0 !important;
  z-index: -1 !important;
}

.nav-sidebar .nav-link:hover::before {
  width: 100% !important;
}

.nav-sidebar .nav-link:hover {
  color: var(--accent-gold) !important;
  transform: translateX(5px) !important;
  box-shadow: var(--shadow-sm) !important;
}

.nav-sidebar .nav-link i {
  transition: all var(--transition-fast) ease !important;
  margin-right: var(--spacing-sm) !important;
}

.nav-sidebar .nav-link:hover i {
  color: var(--accent-gold) !important;
  transform: scale(1.1) !important;
}

.nav-sidebar .nav-link p {
  transition: all var(--transition-fast) ease !important;
  font-size: 0.875rem !important;
}

.nav-sidebar .nav-link:hover p {
  color: var(--accent-gold) !important;
}

/* Active and Open States */
.nav-sidebar .nav-item > .nav-link.active,
.nav-sidebar .nav-item.menu-open > .nav-link {
  background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-gold-hover) 100%) !important;
  color: #000 !important;
  box-shadow: var(--shadow-md) !important;
  transform: translateX(8px) !important;
}

.nav-sidebar .nav-item > .nav-link.active::before,
.nav-sidebar .nav-item.menu-open > .nav-link::before {
  width: 100% !important;
  background: rgba(0, 0, 0, 0.1) !important;
}

.nav-sidebar .nav-item > .nav-link.active p,
.nav-sidebar .nav-item > .nav-link.active i,
.nav-sidebar .nav-item.menu-open > .nav-link p,
.nav-sidebar .nav-item.menu-open > .nav-link i {
  color: #000 !important;
  font-weight: 600 !important;
}

.nav-sidebar .nav-item > .nav-link.active i,
.nav-sidebar .nav-item.menu-open > .nav-link i {
  transform: scale(1.1) !important;
}

/* Submenu Styles */
.nav-treeview {
  background: rgba(0, 0, 0, 0.05) !important;
  margin: 0 var(--spacing-sm) !important;
  border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;
  padding: var(--spacing-xs) 0 !important;
}

.nav-treeview > .nav-item > .nav-link {
  padding: var(--spacing-xs) var(--spacing-lg) !important;
  font-size: 0.8rem !important;
  color: var(--text-muted) !important;
  margin: 0 !important;
  border-radius: 0 !important;
}

.nav-treeview > .nav-item > .nav-link.active {
  background: var(--gradient-gold) !important;
  color: #000 !important;
  padding-left: var(--spacing-xl) !important;
  position: relative !important;
}

.nav-treeview > .nav-item > .nav-link.active::before {
  content: '' !important;
  position: absolute !important;
  left: var(--spacing-sm) !important;
  top: 50% !important;
  width: 6px !important;
  height: 6px !important;
  background: #000 !important;
  border-radius: 50% !important;
  transform: translateY(-50%) !important;
}

.nav-treeview > .nav-item > .nav-link:hover {
  background: rgba(212, 175, 55, 0.1) !important;
  color: var(--accent-gold) !important;
  padding-left: var(--spacing-lg) !important;
}

.nav-header {
  color: var(--accent-gold) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.1em !important;
  padding: var(--spacing-md) var(--spacing-lg) !important;
  margin: var(--spacing-sm) var(--spacing-sm) var(--spacing-xs) !important;
  border-bottom: 1px solid var(--border-color) !important;
  position: relative !important;
}

.nav-header::after {
  content: '' !important;
  position: absolute !important;
  bottom: -1px !important;
  left: var(--spacing-lg) !important;
  right: var(--spacing-lg) !important;
  height: 1px !important;
  background: var(--gradient-gold) !important;
}

/* Modern Modals - Enhanced */
.modal-content {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-xl) !important;
  overflow: hidden !important;
}

.modal-header {
  border-bottom: 1px solid var(--border-color) !important;
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%) !important;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0 !important;
  padding: var(--spacing-xl) !important;
}

.modal-title {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
  font-size: 1.25rem !important;
}

/* Modern Alerts - Enhanced */
.alert {
  border-radius: var(--radius-lg) !important;
  border: none !important;
  box-shadow: var(--shadow-md) !important;
  position: relative !important;
  overflow: hidden !important;
}

.alert::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 4px !important;
  height: 100% !important;
  background: var(--gradient-gold) !important;
}

.alert-success {
  background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(212, 175, 55, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid var(--accent-gold) !important;
}

.alert-warning {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid #ffc107 !important;
}

.alert-danger {
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.1) 0%, rgba(220, 53, 69, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid #dc3545 !important;
}

.alert-info {
  background: linear-gradient(135deg, rgba(23, 162, 184, 0.1) 0%, rgba(23, 162, 184, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid #17a2b8 !important;
}

/* Modern Pagination - Enhanced */
.page-link {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: var(--radius-lg) !important;
  transition: all var(--transition-normal) cubic-bezier(0.4, 0, 0.2, 1) !important;
  padding: var(--spacing-sm) var(--spacing-md) !important;
  margin: 0 var(--spacing-xs) !important;
  border: 2px solid var(--border-color) !important;
}

.page-item.active .page-link {
  background: var(--gradient-gold) !important;
  border-color: var(--accent-gold) !important;
  color: #000 !important;
  box-shadow: var(--shadow-gold) !important;
}

.page-link:hover {
  background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--accent-gold-light) 100%) !important;
  color: var(--accent-gold) !important;
  transform: translateY(-2px) scale(1.05) !important;
  box-shadow: var(--shadow-md) !important;
  border-color: var(--accent-gold-light) !important;
}

/* Modern Info Boxes */
.info-box {
  background: var(--bg-card) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid var(--accent-gold) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  transition: all var(--transition-fast) !important;
}

.info-box:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px) !important;
}

.info-box .info-box-icon {
  background: var(--gradient-gold-light) !important;
  color: var(--accent-gold) !important;
  border-radius: var(--radius-md) !important;
}

/* Modern Tables */
.table {
  background: var(--bg-card) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-sm) !important;
}

.table thead th {
  background: var(--gradient-gold) !important;
  color: #000 !important;
  font-weight: 600 !important;
  border: none !important;
  text-transform: uppercase !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.05em !important;
}

.table td {
  border-color: var(--border-color) !important;
  transition: background-color var(--transition-fast) !important;
}

.table-hover tbody tr:hover {
  background-color: var(--bg-secondary) !important;
  color: var(--accent-gold) !important;
}

/* Modern Buttons */
.btn {
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  transition: all var(--transition-fast) !important;
  border: none !important;
  box-shadow: var(--shadow-sm) !important;
}

.btn-primary {
  background: var(--gradient-gold) !important;
  color: #000 !important;
}

.btn-primary:hover {
  background: var(--accent-gold-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-md) !important;
}

.btn-secondary {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-color) !important;
}

.btn-secondary:hover {
  background: var(--bg-secondary) !important;
  border-color: var(--accent-gold) !important;
  color: var(--accent-gold) !important;
}

/* Modern Forms */
.form-control {
  border-radius: var(--radius-md) !important;
  border: 2px solid var(--border-color) !important;
  transition: all var(--transition-fast) !important;
  background: var(--bg-card) !important;
  color: var(--text-primary) !important;
}

.form-control:focus {
  border-color: var(--accent-gold) !important;
  box-shadow: 0 0 0 0.2rem rgba(212, 175, 55, 0.25) !important;
}

/* Modern Breadcrumbs */
.breadcrumb {
  background: transparent !important;
  padding-left: 0 !important;
}

.breadcrumb-item a {
  color: var(--text-secondary) !important;
  text-decoration: none !important;
  transition: color var(--transition-fast) !important;
}

.breadcrumb-item a:hover {
  color: var(--accent-gold) !important;
}

.breadcrumb-item.active {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
}

/* Modern Modals */
.modal-content {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-xl) !important;
}

.modal-header {
  border-bottom: 1px solid var(--border-color) !important;
  background: var(--gradient-card) !important;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
}

.modal-title {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
}

/* Modern Alerts */
.alert {
  border-radius: var(--radius-md) !important;
  border: none !important;
  box-shadow: var(--shadow-sm) !important;
}

.alert-success {
  background: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%) !important;
  color: #155724 !important;
}

.alert-warning {
  background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%) !important;
  color: #856404 !important;
}

.alert-danger {
  background: linear-gradient(135deg, #f8d7da 0%, #f5c6cb 100%) !important;
  color: #721c24 !important;
}

.alert-info {
  background: linear-gradient(135deg, #d1ecf1 0%, #bee5eb 100%) !important;
  color: #0c5460 !important;
}

/* Modern Pagination */
.page-link {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: var(--radius-md) !important;
  transition: all var(--transition-fast) !important;
}

.page-item.active .page-link {
  background: var(--gradient-gold) !important;
  border-color: var(--accent-gold) !important;
  color: #000 !important;
  box-shadow: var(--shadow-md) !important;
}

.page-link:hover {
  background: var(--bg-secondary) !important;
  color: var(--accent-gold) !important;
  transform: translateY(-1px) !important;
}

/* Loading Animation */
@keyframes shimmer {
  0% { background-position: -468px 0; }
  100% { background-position: 468px 0; }
}

.loading-shimmer {
  animation: shimmer 1.5s infinite linear;
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 468px 100%;
}

/* Pulse Animation for Active Elements */
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(212, 175, 55, 0.4); }
  70% { box-shadow: 0 0 0 10px rgba(212, 175, 55, 0); }
  100% { box-shadow: 0 0 0 0 rgba(212, 175, 55, 0); }
}

/* ========================================
   LOGIN MODERNO - ESTILOS ESPECÍFICOS
   ======================================== */

/* Container principal do login */
.modern-login-bg {
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  position: relative !important;
  min-height: 100vh !important;
}

.modern-login-bg::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: rgba(0, 0, 0, 0.6) !important;
  z-index: 1 !important;
}

/* Card principal do login */
.modern-login-card {
  background: var(--bg-card) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  border: 1px solid var(--border-color) !important;
  position: relative !important;
  z-index: 2 !important;
  max-width: 400px !important;
  margin: 0 auto !important;
  backdrop-filter: blur(10px) !important;
  background: rgba(255, 255, 255, 0.95) !important;
}

/* Logo container melhorado - VERSÃO PREMIUM */
.modern-logo-container {
  text-align: center !important;
  margin-bottom: 30px !important;
  position: relative !important;
}

/* Logo container melhorado - VERSÃO PREMIUM */
.modern-logo-container {
  text-align: center !important;
  margin-bottom: 30px !important;
  position: relative !important;
}

.modern-logo-wrapper {
  display: inline-block !important;
  padding: 20px !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.85) 100%) !important;
  border-radius: 50% !important;
  box-shadow:
    0 0 0 3px rgba(212, 175, 55, 0.2),
    0 8px 32px rgba(0, 0, 0, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.8) !important;
  backdrop-filter: blur(15px) !important;
  border: 4px solid transparent !important;
  background-clip: padding-box !important;
  position: relative !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  animation: logoPulse 3s ease-in-out infinite !important;
  overflow: hidden !important;
}

.modern-logo-wrapper::before {
  content: '' !important;
  position: absolute !important;
  top: -4px !important;
  left: -4px !important;
  right: -4px !important;
  bottom: -4px !important;
  background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-gold-hover) 50%, var(--accent-gold) 100%) !important;
  border-radius: 50% !important;
  z-index: -1 !important;
  opacity: 0 !important;
  transition: opacity 0.4s ease !important;
}

.modern-logo-wrapper::after {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 200px !important;
  height: 200px !important;
  background: radial-gradient(circle, rgba(212, 175, 55, 0.1) 0%, transparent 70%) !important;
  border-radius: 50% !important;
  transform: translate(-50%, -50%) scale(0) !important;
  transition: transform 0.6s ease !important;
  pointer-events: none !important;
}

.modern-logo-wrapper:hover {
  transform: scale(1.08) rotate(2deg) !important;
  box-shadow:
    0 0 0 6px rgba(212, 175, 55, 0.3),
    0 15px 50px rgba(0, 0, 0, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  animation: none !important;
}

.modern-logo-wrapper:hover::before {
  opacity: 1 !important;
}

.modern-logo-wrapper:hover::after {
  transform: translate(-50%, -50%) scale(1) !important;
}

.modern-logo {
  max-width: 140px !important;
  height: auto !important;
  border-radius: var(--radius-md) !important;
  transition: all 0.3s ease !important;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.1)) !important;
  position: relative !important;
  z-index: 2 !important;
}

.modern-logo-wrapper:hover .modern-logo {
  transform: scale(1.05) !important;
  filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.15)) !important;
}

/* Animação sutil de pulso para o logo */
@keyframes logoPulse {
  0%, 100% {
    transform: scale(1) !important;
    box-shadow:
      0 0 0 3px rgba(212, 175, 55, 0.2),
      0 8px 32px rgba(0, 0, 0, 0.15),
      inset 0 1px 0 rgba(255, 255, 255, 0.8) !important;
  }
  50% {
    transform: scale(1.02) !important;
    box-shadow:
      0 0 0 4px rgba(212, 175, 55, 0.25),
      0 10px 40px rgba(0, 0, 0, 0.18),
      inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  }
}

/* EFEITO DE PARTICULAS ADICIONAL PARA O LOGO */
.modern-logo-container::before {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 300px !important;
  height: 300px !important;
  background:
    radial-gradient(2px 2px at 20px 30px, rgba(212, 175, 55, 0.3), transparent),
    radial-gradient(2px 2px at 40px 70px, rgba(212, 175, 55, 0.2), transparent),
    radial-gradient(1px 1px at 90px 40px, rgba(212, 175, 55, 0.4), transparent),
    radial-gradient(1px 1px at 130px 80px, rgba(212, 175, 55, 0.3), transparent),
    radial-gradient(2px 2px at 160px 30px, rgba(212, 175, 55, 0.2), transparent) !important;
  background-repeat: repeat !important;
  background-size: 200px 100px !important;
  border-radius: 50% !important;
  transform: translate(-50%, -50%) !important;
  animation: sparkle 4s linear infinite !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transition: opacity 0.5s ease !important;
}

.modern-logo-container:hover::before {
  opacity: 0.6 !important;
}

/* =============================================
   PÁGINA DE INFORMAÇÕES - DESIGN PROFISSIONAL
   ============================================= */

/* Estilos para o cabeçalho profissional */
.information-header {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  color: white !important;
  border-radius: 15px !important;
  box-shadow: 0 10px 30px rgba(102, 126, 234, 0.3) !important;
  margin-bottom: 2rem !important;
}

.information-header .display-4 {
  font-weight: 700 !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.information-header .lead {
  font-size: 1.2rem !important;
  opacity: 0.9 !important;
}

/* Cards com prioridades visuais distintas */
.priority-card {
  transition: all 0.3s ease !important;
  border-width: 2px !important;
}

.priority-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15) !important;
}

/* Área crítica - vermelho */
.priority-high {
  border-color: #dc3545 !important;
}

.priority-high .card-header {
  background: linear-gradient(135deg, #dc3545 0%, #c82333 100%) !important;
}

/* Área média - amarelo/laranja */
.priority-medium {
  border-color: #ffc107 !important;
}

.priority-medium .card-header {
  background: linear-gradient(135deg, #ffc107 0%, #fd7e14 100%) !important;
}

/* Área baixa - cinza/azul */
.priority-low {
  border-color: #6c757d !important;
}

.priority-low .card-header {
  background: linear-gradient(135deg, #6c757d 0%, #495057 100%) !important;
}

/* Cards de serviços específicos */
.service-card {
  transition: all 0.3s ease !important;
  border-radius: 10px !important;
  overflow: hidden !important;
}

.service-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15) !important;
}

.service-card .card-header {
  border-radius: 10px 10px 0 0 !important;
  padding: 1rem !important;
}

.service-card .card-body {
  padding: 1.5rem !important;
}

/* Melhorando os inputs dos geradores */
.generator-input {
  border-radius: 8px !important;
  font-family: 'Courier New', monospace !important;
  font-weight: 500 !important;
  letter-spacing: 0.5px !important;
}

.generator-btn {
  border-radius: 0 8px 8px 0 !important;
  transition: all 0.2s ease !important;
}

.generator-btn:hover {
  transform: scale(1.05) !important;
}

/* Alertas melhorados */
.information-alert {
  border-radius: 10px !important;
  border: none !important;
  padding: 1.5rem !important;
}

.information-alert .alert-heading {
  font-weight: 600 !important;
  margin-bottom: 1rem !important;
}

/* Área de informações adicionais */
.info-card {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  border-radius: 10px !important;
  transition: all 0.3s ease !important;
}

.info-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important;
}

.info-card .card-body {
  text-align: center !important;
}

.info-card i {
  opacity: 0.8 !important;
}

/* Rodapé da informação */
.info-footer {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  border-radius: 8px !important;
  padding: 1rem 1.5rem !important;
}

.info-footer .fa-clock {
  animation: pulse 2s infinite !important;
}

@keyframes pulse {
  0% { opacity: 1; }
  50% { opacity: 0.5; }
  100% { opacity: 1; }
}

/* Responsividade melhorada */
@media (max-width: 768px) {
  .information-header {
    padding: 1.5rem !important;
    text-align: center !important;
  }

  .information-header .col-md-8,
  .information-header .col-md-4 {
    margin-bottom: 1rem !important;
  }

  .service-card {
    margin-bottom: 1rem !important;
  }
}

/* Animações de entrada */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.priority-card,
.service-card,
.info-card {
  animation: fadeInUp 0.6s ease-out !important;
}

.priority-card:nth-child(1) { animation-delay: 0.1s !important; }
.priority-card:nth-child(2) { animation-delay: 0.2s !important; }
.priority-card:nth-child(3) { animation-delay: 0.3s !important; }

/* Badges de prioridade */
.priority-badge {
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

/* =============================================
   AVISOS LEGAIS E SEGURANÇA - IPTV
   ============================================= */

/* Card principal de avisos legais */
.legal-security-card {
  border: 3px solid #ffc107 !important;
  background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%) !important;
  box-shadow: 0 10px 30px rgba(255, 193, 7, 0.3) !important;
}

.legal-security-card .card-header {
  background: linear-gradient(135deg, #ffc107 0%, #fd7e14 100%) !important;
  color: #212529 !important;
  border-bottom: 3px solid #e0a800 !important;
}

.legal-security-card .alert-warning {
  background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%) !important;
  border: 2px solid #ffc107 !important;
  border-radius: 10px !important;
}

.legal-security-card .alert-danger {
  background: linear-gradient(135deg, #f8d7da 0%, #f5c6cb 100%) !important;
  border: 2px solid #dc3545 !important;
  border-radius: 10px !important;
}

.legal-security-card .alert-dark {
  background: linear-gradient(135deg, #d1ecf1 0%, #bee5eb 100%) !important;
  border: 2px solid #17a2b8 !important;
  border-radius: 10px !important;
}

/* Ícones destacados */
.legal-icon {
  animation: pulse-legal 2s infinite !important;
}

@keyframes pulse-legal {
  0% { transform: scale(1); }
  50% { transform: scale(1.1); }
  100% { transform: scale(1); }
}

/* Botão de imprimir termos */
.print-terms-btn {
  transition: all 0.3s ease !important;
}

.print-terms-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 5px 15px rgba(0, 123, 255, 0.3) !important;
}

/* Responsividade para avisos legais */
@media (max-width: 768px) {
  .legal-security-card .card-body {
    padding: 1rem !important;
  }

  .legal-security-card .col-md-6 {
    margin-bottom: 1rem !important;
  }

  .legal-security-card .alert {
    padding: 1rem !important;
  }
}

/* Destaque para textos importantes */
.legal-highlight {
  background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%) !important;
  padding: 0.5rem 1rem !important;
  border-radius: 8px !important;
  border-left: 4px solid #ffc107 !important;
  font-weight: 600 !important;
}

/* Animação de entrada para avisos legais */
@keyframes slideInLegal {
  from {
    opacity: 0;
    transform: translateX(-50px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.legal-security-card {
  animation: slideInLegal 0.8s ease-out !important;
}

/* Melhorando a legibilidade */
.legal-text {
  line-height: 1.6 !important;
  font-size: 0.95rem !important;
}

.legal-list {
  padding-left: 1.2rem !important;
}

.legal-list li {
  margin-bottom: 0.5rem !important;
  padding-left: 0.5rem !important;
}

/* Card de atualização de termos */
.terms-update-card {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  border-radius: 8px !important;
}

.terms-update-card .fa-calendar-check {
  animation: pulse-legal 3s infinite !important;
}

.modern-focus {
  background: var(--accent-gold) !important;
}

.modern-icon {
  color: var(--accent-gold) !important;
  left: 15px !important;
}

/* Botão de login moderno */
.modern-login-btn {
  background: linear-gradient(135deg, var(--accent-gold) 0%, var(--accent-gold-hover) 100%) !important;
  border: none !important;
  border-radius: var(--radius-md) !important;
  color: #000 !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  padding: 12px 30px !important;
  transition: all var(--transition-normal) ease !important;
  box-shadow: var(--shadow-md) !important;
  font-family: 'Inter', sans-serif !important;
}

.modern-login-btn:hover {
  background: linear-gradient(135deg, var(--accent-gold-hover) 0%, #b8941f 100%) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* Links modernos */
.modern-links {
  font-family: 'Inter', sans-serif !important;
}

.modern-link {
  color: var(--accent-gold) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  transition: all var(--transition-fast) ease !important;
}

.modern-link:hover {
  color: var(--accent-gold-hover) !important;
  text-decoration: underline !important;
}

/* Footer moderno */
.modern-footer {
  position: absolute !important;
  bottom: 20px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  text-align: center !important;
  z-index: 2 !important;
}

.modern-version,
.modern-powered {
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 12px !important;
  margin: 0 !important;
  font-family: 'Inter', sans-serif !important;
}

.modern-powered a {
  color: var(--accent-gold) !important;
  text-decoration: none !important;
}

.modern-powered a:hover {
  color: var(--accent-gold-hover) !important;
}

/* ReCAPTCHA moderno */
.modern-recaptcha {
  margin-bottom: 20px !important;
  display: flex !important;
  justify-content: center !important;
}

/* Título moderno para forget password */
.modern-title {
  color: var(--text-primary) !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 1.5rem !important;
  text-align: center !important;
}

/* Informações modernas */
.modern-info {
  font-family: 'Inter', sans-serif !important;
}

.modern-info .txt1 {
  color: var(--text-secondary) !important;
  font-size: 0.9rem !important;
  line-height: 1.5 !important;
}

.pulse {
  animation: pulse 2s infinite;
}

/* Modern Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Inter', sans-serif !important;
  color: var(--text-primary) !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  margin-bottom: 0.5rem !important;
}

h1 {
  font-size: 2.5rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
}

h2 {
  font-size: 2rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.025em !important;
}

h3 {
  font-size: 1.75rem !important;
  font-weight: 600 !important;
}

h4 {
  font-size: 1.5rem !important;
  font-weight: 600 !important;
}

h5 {
  font-size: 1.25rem !important;
  font-weight: 600 !important;
}

h6 {
  font-size: 1rem !important;
  font-weight: 600 !important;
}

.content-header h1 {
  font-size: 2.5rem !important;
  font-weight: 700 !important;
  background: var(--gradient-gold) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  margin-bottom: 1rem !important;
}

/* Text Utilities */
.text-primary { color: var(--text-primary) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-muted { color: var(--text-muted) !important; }
.text-gold { color: var(--accent-gold) !important; }
.text-gold-hover:hover { color: var(--accent-gold-hover) !important; }

/* Font Weights */
.font-light { font-weight: 300 !important; }
.font-normal { font-weight: 400 !important; }
.font-medium { font-weight: 500 !important; }
.font-semibold { font-weight: 600 !important; }
.font-bold { font-weight: 700 !important; }

/* Text Sizes */
.text-xs { font-size: 0.75rem !important; }
.text-sm { font-size: 0.875rem !important; }
.text-base { font-size: 1rem !important; }
.text-lg { font-size: 1.125rem !important; }
.text-xl { font-size: 1.25rem !important; }
.text-2xl { font-size: 1.5rem !important; }
.text-3xl { font-size: 1.875rem !important; }
.text-4xl { font-size: 2.25rem !important; }
.text-5xl { font-size: 3rem !important; }

/* Line Heights */
.leading-tight { line-height: 1.25 !important; }
.leading-snug { line-height: 1.375 !important; }
.leading-normal { line-height: 1.5 !important; }
.leading-relaxed { line-height: 1.625 !important; }
.leading-loose { line-height: 2 !important; }

/* Text Alignment */
.text-left { text-align: left !important; }
.text-center { text-align: center !important; }
.text-right { text-align: right !important; }
.text-justify { text-align: justify !important; }

/* Text Transform */
.uppercase { text-transform: uppercase !important; }
.lowercase { text-transform: lowercase !important; }
.capitalize { text-transform: capitalize !important; }
.normal-case { text-transform: none !important; }

/* Letter Spacing */
.tracking-tighter { letter-spacing: -0.05em !important; }
.tracking-tight { letter-spacing: -0.025em !important; }
.tracking-normal { letter-spacing: 0em !important; }
.tracking-wide { letter-spacing: 0.025em !important; }
.tracking-wider { letter-spacing: 0.05em !important; }
.tracking-widest { letter-spacing: 0.1em !important; }

/* Layout principal - correção para posicionamento */
.wrapper {
  position: relative !important;
  overflow-x: hidden !important;
  min-height: 100vh !important;
}

.content-wrapper {
  background: var(--bg-primary) !important;
  margin-left: 250px !important;
  min-height: 100vh !important;
  transition: margin-left var(--transition-normal) ease !important;
  position: relative !important;
  z-index: 1 !important;
  padding-top: 50px !important;
}

/* Navbar fixo - altura reduzida */
.main-header.navbar {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 1030 !important;
  height: 50px !important;
  background: var(--bg-navbar) !important;
  box-shadow: var(--shadow-sm) !important;
  border-bottom: 2px solid var(--accent-gold) !important;
}

/* Sidebar fixo - posição NO TOPO com tamanho original */
.main-sidebar {
  position: fixed !important;
  top: 0px !important;
  left: 0 !important;
  height: 100vh !important;
  width: 250px !important;
  z-index: 1020 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  background: var(--bg-sidebar) !important;
  border-right: 1px solid var(--border-color) !important;
}

/* Responsividade sidebar */
@media (max-width: 992px) {
  .content-wrapper {
    margin-left: 0 !important;
    transition: margin-left var(--transition-normal) ease !important;
  }

  .main-sidebar {
    transform: translateX(-100%) !important;
    transition: transform 0.3s ease-in-out !important;
    width: 280px !important;
  }

  .sidebar-open .main-sidebar {
    transform: translateX(0) !important;
  }

  .navbar-expand-lg .navbar-nav .nav-link {
    padding: 0.4rem 0.8rem !important;
  }

  .card {
    margin-bottom: 0.8rem !important;
  }

  .info-box {
    margin-bottom: 0.8rem !important;
  }
}

/* Content-header proporcional ao texto menor */
.content-header {
  padding: 0.5rem 0.75rem !important;
  margin-bottom: 0.5rem !important;
  background: var(--bg-card) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-sm) !important;
  position: relative !important;
  z-index: 2 !important;
  border: 1px solid var(--border-color) !important;
}

.content {
  padding: var(--spacing-md) !important;
  position: relative !important;
  z-index: 1 !important;
}

/* Ajustes de espaçamento responsivo */
@media (max-width: 1200px) {
  .content-wrapper {
    margin-left: 240px !important;
  }

  .main-sidebar {
    width: 240px !important;
  }

  .content-header h1 {
    font-size: 1.2rem !important;
  }

  .info-box .info-box-icon {
    width: 55px !important;
    height: 55px !important;
    font-size: 1.3rem !important;
  }

  .card-title {
    font-size: 1rem !important;
  }
}

@media (max-width: 992px) {
  .content-wrapper {
    margin-left: 0 !important;
    transition: margin-left var(--transition-normal) ease !important;
  }

  .main-sidebar {
    transform: translateX(-100%) !important;
    transition: transform 0.3s ease-in-out !important;
  }

  .sidebar-open .main-sidebar {
    transform: translateX(0) !important;
  }

  .navbar-expand-lg .navbar-nav .nav-link {
    padding: 0.4rem 0.8rem !important;
  }

  .card {
    margin-bottom: 0.8rem !important;
  }

  .info-box {
    margin-bottom: 0.8rem !important;
  }

  .content-header {
    padding: 0.4rem 0.6rem !important;
    margin-bottom: 0.4rem !important;
  }

  .content {
    padding: var(--spacing-sm) !important;
  }
}

@media (max-width: 768px) {
  /* Mobile First Design */
  .content-wrapper {
    margin-left: 0 !important;
  }

  .main-sidebar {
    width: 260px !important;
    top: 0 !important;
    height: 100vh !important;
    z-index: 1040 !important;
  }

  .content-header {
    padding: 0.4rem !important;
    margin-bottom: 0.4rem !important;
  }

  .content-header h1 {
    font-size: 1.4rem !important;
  }

  .content {
    padding: var(--spacing-sm) !important;
  }

  .breadcrumb {
    font-size: 0.75rem !important;
  }

  /* Mobile Cards */
  .card {
    border-radius: var(--radius-md) !important;
    margin-bottom: var(--spacing-sm) !important;
  }

  .card-header {
    padding: var(--spacing-sm) !important;
    border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
  }

  .card-body {
    padding: var(--spacing-sm) !important;
  }

  /* Mobile Info Boxes */
  .info-box {
    border-radius: var(--radius-md) !important;
    margin-bottom: var(--spacing-sm) !important;
  }

  .info-box .info-box-icon {
    width: 45px !important;
    height: 45px !important;
    font-size: 1.1rem !important;
  }

  .info-box .info-box-content {
    padding: var(--spacing-sm) !important;
  }

  .info-box .info-box-text {
    font-size: 0.75rem !important;
  }

  .info-box .info-box-number {
    font-size: 1.1rem !important;
  }

  /* Mobile Tables */
  .table {
    font-size: 0.75rem !important;
  }

  .table th,
  .table td {
    padding: var(--spacing-xs) !important;
  }

  /* Mobile Buttons */
  .btn {
    padding: var(--spacing-xs) var(--spacing-sm) !important;
    font-size: 0.75rem !important;
    margin: var(--spacing-xs) !important;
  }

  .btn-group .btn {
    margin: 0 !important;
  }

  /* Mobile Forms */
  .form-control {
    font-size: 0.85rem !important;
    padding: var(--spacing-xs) var(--spacing-sm) !important;
  }

  .form-group {
    margin-bottom: var(--spacing-sm) !important;
  }

  /* Mobile Navigation */
  .main-header.navbar {
    padding: var(--spacing-xs) var(--spacing-sm) !important;
  }

  .navbar-nav .nav-link {
    padding: var(--spacing-xs) !important;
  }

  /* Mobile Typography */
  h1 { font-size: 1.4rem !important; }
  h2 { font-size: 1.2rem !important; }
  h3 { font-size: 1.05rem !important; }
  h4 { font-size: 0.95rem !important; }
  h5 { font-size: 0.85rem !important; }
  h6 { font-size: 0.75rem !important; }

  /* Mobile Spacing */
  .container-fluid {
    padding-left: var(--spacing-xs) !important;
    padding-right: var(--spacing-xs) !important;
  }

  .row {
    margin-left: calc(-1 * var(--spacing-xs)) !important;
    margin-right: calc(-1 * var(--spacing-xs)) !important;
  }

  .col, .col-1, .col-2, .col-3, .col-4, .col-5, .col-6,
  .col-7, .col-8, .col-9, .col-10, .col-11, .col-12 {
    padding-left: var(--spacing-xs) !important;
    padding-right: var(--spacing-xs) !important;
  }
}

/* Animações melhoradas para elementos interativos */
.card {
  transition: all var(--transition-fast) cubic-bezier(0.4, 0, 0.2, 1) !important;
  border-radius: var(--radius-md) !important;
}

.card:hover {
  transform: translateY(-3px) !important;
  box-shadow: var(--shadow-lg) !important;
}

.info-box {
  transition: all var(--transition-fast) cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.info-box:hover {
  transform: translateY(-2px) scale(1.02) !important;
  box-shadow: var(--shadow-lg) !important;
}

.btn {
  transition: all var(--transition-fast) cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-md) !important;
}

.nav-sidebar .nav-link {
  transition: all var(--transition-fast) cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.nav-sidebar .nav-link:hover {
  transform: translateX(5px) !important;
  background: rgba(212, 175, 55, 0.1) !important;
}

/* Melhor espaçamento para forms */
.form-group {
  margin-bottom: var(--spacing-sm) !important;
}

.form-control {
  padding: var(--spacing-xs) var(--spacing-sm) !important;
  font-size: 0.8rem !important;
  border-radius: var(--radius-sm) !important;
  border: 1px solid var(--border-color) !important;
}

.form-control:focus {
  border-color: var(--accent-gold) !important;
  box-shadow: 0 0 0 0.2rem rgba(212, 175, 55, 0.25) !important;
}

/* Tabelas responsivas melhoradas */
.table-responsive {
  border-radius: var(--radius-lg) !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: thin !important;
  scrollbar-color: var(--accent-gold) transparent !important;
  box-shadow: var(--shadow-md) !important;
  background: var(--bg-card) !important;
  border: 1px solid var(--border-color) !important;
}

/* Abordagem alternativa com viewport units para melhor compatibilidade com zoom */
/* Esta regra funciona independente do nível de zoom */
@media (max-width: 75rem) { /* 1200px equivalente */
  .table th:nth-child(4),
  .table td:nth-child(4),
  .table th:nth-child(5),
  .table td:nth-child(5) {
    display: none !important;
  }
}

@media (max-width: 68.75rem) { /* 1100px equivalente */
  .table th:nth-child(7),
  .table td:nth-child(7) {
    display: none !important;
  }
}

@media (max-width: 56.25rem) { /* 900px equivalente */
  .table th:nth-child(9),
  .table td:nth-child(9) {
    display: none !important;
  }
}

/* Melhor espaçamento para filtros */
.filters .row > div {
  margin-bottom: var(--spacing-md) !important;
}

@media (max-width: 768px) {
  .filters .row > div {
    margin-bottom: var(--spacing-sm) !important;
  }

  .filters .col-md-3 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}

/* Indicador visual de scroll horizontal */
.table-responsive::after {
  content: "← Deslize para ver mais colunas →";
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.8rem;
  color: var(--text-muted);
  background: var(--bg-card);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  opacity: 0;
  transition: opacity var(--transition-fast) ease;
  border: 1px solid var(--border-color);
}

/* Garantir que a coluna de ações SEMPRE fique visível */
.table th:last-child,
.table td:last-child {
  display: table-cell !important;
  min-width: 120px !important;
}

/* Em mobile, ações ficam menores mas sempre visíveis */
@media (max-width: 768px) {
  .table th:last-child,
  .table td:last-child {
    min-width: 100px !important;
  }
}

/* Layout compacto equivalente a zoom 70% */
.table {
  font-size: 0.8rem !important;
}

.table th,
.table td {
  padding: var(--spacing-xs) var(--spacing-sm) !important;
  vertical-align: middle !important;
  border-color: var(--border-color) !important;
}

.table .btn {
  padding: 0.15rem 0.3rem !important;
  font-size: 0.7rem !important;
  margin: 0.05rem !important;
  border-radius: var(--radius-xs) !important;
}

.table .btn i {
  font-size: 0.65rem !important;
}

/* Ocultar colunas ID, Revendedor e Adicionado por padrão para melhor aproveitamento horizontal */
.table th:nth-child(1),
.table td:nth-child(1),
.table th:nth-child(6),
.table td:nth-child(6),
.table th:nth-child(8),
.table td:nth-child(8) {
  display: none !important;
}

/* Ajustar larguras das colunas restantes */
.table th:nth-child(2),
.table td:nth-child(2) {
  width: 150px !important;
  min-width: 150px !important;
}

.table th:nth-child(3),
.table td:nth-child(3) {
  width: 120px !important;
  min-width: 120px !important;
}

.table th:nth-child(4),
.table td:nth-child(4) {
  width: 80px !important;
  min-width: 80px !important;
}

.table th:nth-child(5),
.table td:nth-child(5) {
  width: 100px !important;
  min-width: 100px !important;
}

.table th:nth-child(6),
.table td:nth-child(6) {
  width: 90px !important;
  min-width: 90px !important;
}

.table th:nth-child(7),
.table td:nth-child(7) {
  width: 90px !important;
  min-width: 90px !important;
}

.table th:nth-child(9),
.table td:nth-child(9) {
  width: 100px !important;
  min-width: 100px !important;
}

.table th:nth-child(10),
.table td:nth-child(10) {
  width: 80px !important;
  min-width: 80px !important;
}

.table th:last-child,
.table td:last-child {
  width: 160px !important;
  min-width: 160px !important;
}

.table-hover tbody tr:hover {
  background-color: var(--bg-secondary) !important;
  color: var(--accent-gold) !important;
}

/* Botões melhorados */
.btn {
  padding: var(--spacing-xs) var(--spacing-md) !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  border-radius: var(--radius-sm) !important;
  border: 1px solid transparent !important;
  transition: all var(--transition-fast) !important;
  margin: 0 var(--spacing-xs) var(--spacing-xs) 0 !important;
}

.btn:last-child {
  margin-right: 0 !important;
}

.btn-primary {
  background: var(--gradient-gold) !important;
  color: #000 !important;
}

.btn-primary:hover {
  background: var(--accent-gold-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-sm) !important;
}

/* Modern Grid System */
.row {
  margin-left: calc(-1 * var(--spacing-sm)) !important;
  margin-right: calc(-1 * var(--spacing-sm)) !important;
}

.col,
.col-1, .col-2, .col-3, .col-4, .col-5, .col-6,
.col-7, .col-8, .col-9, .col-10, .col-11, .col-12 {
  padding-left: var(--spacing-sm) !important;
  padding-right: var(--spacing-sm) !important;
}

/* Better Info Box Styling */
.info-box {
  background: var(--bg-card) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  border-left: 4px solid var(--accent-gold) !important;
  transition: all var(--transition-fast) !important;
}

.info-box:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px) !important;
}

.info-box .info-box-icon {
  background: var(--gradient-gold-light) !important;
  color: var(--accent-gold) !important;
  border-radius: var(--radius-md) !important;
}

.info-box-content {
  padding: var(--spacing-lg) !important;
}

.info-box-text {
  font-size: 0.875rem !important;
  margin-bottom: var(--spacing-xs) !important;
}

.info-box-number {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
}

/* Navbar melhorado com animações */
.navbar-nav .nav-link {
  padding: var(--spacing-sm) var(--spacing-md) !important;
  transition: all var(--transition-fast) cubic-bezier(0.4, 0, 0.2, 1) !important;
  border-radius: var(--radius-sm) !important;
  margin: 0 var(--spacing-xs) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.navbar-nav .nav-link:hover {
  color: var(--accent-gold) !important;
  background: rgba(212, 175, 55, 0.1) !important;
  transform: translateY(-1px) !important;
}

/* Better Sidebar Spacing */
.nav-sidebar .nav-link {
  padding: var(--spacing-sm) var(--spacing-lg) !important;
}

.nav-sidebar .nav-link p {
  margin: 0 !important;
}

/* Improved Breadcrumb */
.breadcrumb {
  background: transparent !important;
  padding: var(--spacing-md) 0 !important;
  margin-bottom: var(--spacing-lg) !important;
}

.breadcrumb-item + .breadcrumb-item::before {
  content: "→" !important;
  color: var(--text-muted) !important;
}

.breadcrumb-item a {
  color: var(--text-secondary) !important;
  text-decoration: none !important;
  transition: color var(--transition-fast) !important;
}

.breadcrumb-item a:hover {
  color: var(--accent-gold) !important;
}

.breadcrumb-item.active {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
}

/* Modern Modal Improvements */
.modal-content {
  background: var(--bg-card) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-xl) !important;
  overflow: hidden !important;
}

.modal-header {
  border-bottom: 1px solid var(--border-color) !important;
  background: var(--gradient-card) !important;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0 !important;
  padding: var(--spacing-xl) !important;
}

.modal-title {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
  font-size: 1.25rem !important;
}

.modal-body {
  padding: var(--spacing-xl) !important;
}

.modal-footer {
  padding: var(--spacing-lg) var(--spacing-xl) !important;
  border-top: 1px solid var(--border-color) !important;
}

/* Modern Alert Improvements */
.alert {
  border-radius: var(--radius-lg) !important;
  border: none !important;
  box-shadow: var(--shadow-md) !important;
  position: relative !important;
  overflow: hidden !important;
  padding: var(--spacing-lg) !important;
  margin-bottom: var(--spacing-lg) !important;
}

.alert::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 4px !important;
  height: 100% !important;
  background: var(--gradient-gold) !important;
}

.alert-success {
  background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(212, 175, 55, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid var(--accent-gold) !important;
}

.alert-warning {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.1) 0%, rgba(255, 193, 7, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid #ffc107 !important;
}

.alert-danger {
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.1) 0%, rgba(220, 53, 69, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid #dc3545 !important;
}

.alert-info {
  background: linear-gradient(135deg, rgba(23, 162, 184, 0.1) 0%, rgba(23, 162, 184, 0.05) 100%) !important;
  color: var(--text-primary) !important;
  border-left: 4px solid #17a2b8 !important;
}

/* Modern Pagination */
.page-link {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: var(--radius-lg) !important;
  transition: all var(--transition-normal) cubic-bezier(0.4, 0, 0.2, 1) !important;
  padding: var(--spacing-sm) var(--spacing-md) !important;
  margin: 0 var(--spacing-xs) !important;
  border: 2px solid var(--border-color) !important;
}

.page-item.active .page-link {
  background: var(--gradient-gold) !important;
  border-color: var(--accent-gold) !important;
  color: #000 !important;
  box-shadow: var(--shadow-gold) !important;
}

.page-link:hover {
  background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--accent-gold-light) 100%) !important;
  color: var(--accent-gold) !important;
  transform: translateY(-2px) scale(1.05) !important;
  box-shadow: var(--shadow-md) !important;
  border-color: var(--accent-gold-light) !important;
}

/* Modern Responsive Design */
@media (max-width: 1200px) {
  .content-header h1 {
    font-size: 1.2rem !important;
  }

  .info-box .info-box-icon {
    width: 55px !important;
    height: 55px !important;
    font-size: 1.3rem !important;
  }

  .card-title {
    font-size: 1.1rem !important;
  }
}

@media (max-width: 992px) {
  .main-sidebar {
    transform: translateX(-100%) !important;
    transition: transform 0.3s ease-in-out !important;
    width: 260px !important;
  }

  .sidebar-open .main-sidebar {
    transform: translateX(0) !important;
  }

  .content-wrapper {
    margin-left: 0 !important;
  }

  .navbar-expand-lg .navbar-nav .nav-link {
    padding: 0.5rem 1rem !important;
  }

  .card {
    margin-bottom: 1rem !important;
  }

  .info-box {
    margin-bottom: 1rem !important;
  }
}

@media (max-width: 768px) {
  /* Títulos das páginas menores e elegantes */
  .content-header h1 {
    font-size: 1.2rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important;
  }

  .content-header {
    padding: 0.4rem !important;
    margin-bottom: 0.4rem !important;
  }


  .breadcrumb {
    font-size: 0.8rem !important;
  }

  /* Mobile Cards */
  .card {
    border-radius: 0.75rem !important;
    margin-bottom: 1rem !important;
  }

  .card-header {
    padding: 1rem !important;
    border-radius: 0.75rem 0.75rem 0 0 !important;
  }

  .card-body {
    padding: 1rem !important;
  }

  /* Mobile Info Boxes */
  .info-box {
    border-radius: 0.75rem !important;
    margin-bottom: 1rem !important;
  }

  .info-box .info-box-icon {
    width: 50px !important;
    height: 50px !important;
    font-size: 1.25rem !important;
  }

  .info-box .info-box-content {
    padding: 1rem !important;
  }

  .info-box .info-box-text {
    font-size: 0.8rem !important;
  }

  .info-box .info-box-number {
    font-size: 1.25rem !important;
  }

  /* Mobile Tables */
  .table {
    font-size: 0.8rem !important;
  }

  .table th,
  .table td {
    padding: 0.5rem !important;
  }

  /* Mobile Buttons */
  .btn {
    padding: 0.375rem 0.75rem !important;
    font-size: 0.8rem !important;
    margin: 0.25rem !important;
  }

  .btn-group .btn {
    margin: 0 !important;
  }

  /* Mobile Forms */
  .form-control {
    font-size: 0.9rem !important;
    padding: 0.5rem 0.75rem !important;
  }

  .form-group {
    margin-bottom: 1rem !important;
  }

  /* Mobile Navigation */
  .main-header.navbar {
    padding: 0.5rem 1rem !important;
  }

  .navbar-nav .nav-link {
    padding: 0.5rem !important;
  }

  /* Mobile Sidebar */
  .main-sidebar {
    width: 280px !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    z-index: 1040 !important;
    height: 100vh !important;
  }

  .sidebar-open .main-sidebar {
    transform: translateX(0) !important;
  }

  /* Mobile Typography */
  h1 { font-size: 1.75rem !important; }
  h2 { font-size: 1.5rem !important; }
  h3 { font-size: 1.25rem !important; }
  h4 { font-size: 1.1rem !important; }
  h5 { font-size: 1rem !important; }
  h6 { font-size: 0.9rem !important; }

  /* Mobile Spacing */
  .container-fluid {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }

  .row {
    margin-left: -0.25rem !important;
    margin-right: -0.25rem !important;
  }

  .col, .col-1, .col-2, .col-3, .col-4, .col-5, .col-6,
  .col-7, .col-8, .col-9, .col-10, .col-11, .col-12 {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }

  /* Mobile Modals */
  .modal-dialog {
    margin: 0.5rem !important;
  }

  .modal-content {
    border-radius: 0.5rem !important;
  }

  .modal-header {
    padding: 1rem !important;
    border-radius: 0.5rem 0.5rem 0 0 !important;
  }

  .modal-body {
    padding: 1rem !important;
  }

  .modal-footer {
    padding: 0.75rem 1rem !important;
  }

  /* Mobile Dropdowns */
  .dropdown-menu {
    border-radius: 0.5rem !important;
    margin-top: 0.25rem !important;
  }

  .dropdown-item {
    padding: 0.5rem 1rem !important;
    font-size: 0.875rem !important;
  }

  /* Mobile Alerts */
  .alert {
    padding: 0.75rem !important;
    margin-bottom: 0.75rem !important;
    border-radius: 0.5rem !important;
  }

  /* Mobile Pagination */
  .pagination {
    flex-wrap: wrap !important;
  }

  .page-link {
    padding: 0.375rem 0.5rem !important;
    font-size: 0.75rem !important;
    margin: 0.125rem !important;
  }
}

@media (max-width: 576px) {
  /* Títulos das páginas menores e elegantes */
  .content-header h1 {
    font-size: 1.2rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important;
  }

  .card-title {
    font-size: 1rem !important;
  }

  .info-box .info-box-number {
    font-size: 1.1rem !important;
  }

  .btn {
    width: 100% !important;
    margin-bottom: 0.5rem !important;
  }

  .btn-group {
    width: 100% !important;
  }

  .btn-group .btn {
    width: auto !important;
    flex: 1 !important;
  }

  /* Mobile Table */
  .table-responsive {
    border-radius: 0.5rem !important;
  }

  .table {
    margin-bottom: 0 !important;
  }

  /* Mobile Forms */
  .form-row {
    margin-left: -0.25rem !important;
    margin-right: -0.25rem !important;
  }

  .form-row > .col,
  .form-row > [class*="col-"] {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }

  /* Mobile Sidebar */
  .main-sidebar {
    width: 100% !important;
    z-index: 1050 !important;
  }

  /* Mobile Header */
  .main-header.navbar {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .navbar-nav {
    width: 100% !important;
    justify-content: center !important;
  }

  /* Mobile Footer */
  .main-footer {
    padding: 1rem 0.5rem !important;
    font-size: 0.8rem !important;
  }
}

/* Touch Device Optimizations */
@media (hover: none) and (pointer: coarse) {
  /* Remove hover effects on touch devices */
  .card:hover {
    transform: none !important;
    box-shadow: var(--shadow-md) !important;
  }

  .btn:hover {
    transform: none !important;
  }

  .nav-sidebar .nav-link:hover {
    transform: none !important;
  }

  .info-box:hover {
    transform: none !important;
  }

  /* Optimize for touch */
  .btn {
    min-height: 44px !important;
    padding: 0.75rem 1rem !important;
  }

  .nav-sidebar .nav-link {
    min-height: 48px !important;
    padding: 0.75rem 1rem !important;
  }

  .form-control {
    min-height: 44px !important;
  }

  .dropdown-item {
    min-height: 44px !important;
    padding: 0.75rem 1rem !important;
  }
}

/* High DPI Displays */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .card {
    border-width: 0.5px !important;
  }

  .btn {
    border-width: 1px !important;
  }

  .form-control {
    border-width: 1px !important;
  }
}

/* Dark Mode Responsive Adjustments */
@media (max-width: 768px) {
  .dark-mode .main-sidebar {
    background: linear-gradient(135deg, #0f0f0f 0%, #1a1a1a 100%) !important;
  }

  .dark-mode .card {
    background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%) !important;
  }

  .dark-mode .modal-content {
    background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%) !important;
  }
}

/* Print Styles */
@media print {
  .main-sidebar,
  .main-header.navbar,
  .btn,
  .card {
    box-shadow: none !important;
    background: white !important;
    color: black !important;
  }

  .main-sidebar {
    display: none !important;
  }

  .content-wrapper {
    margin-left: 0 !important;
  }

  .btn {
    border: 1px solid black !important;
  }
}

/* Focus Visible for Accessibility */
.btn:focus-visible,
.nav-link:focus-visible,
.form-control:focus-visible {
  outline: 2px solid var(--accent-gold) !important;
  outline-offset: 2px !important;
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .card {
    animation: none !important;
  }

  .info-box {
    animation: none !important;
  }

  .nav-sidebar .nav-item {
    animation: none !important;
  }
}

/* Modern Footer - Tema Dourado */
.main-footer {
  background: var(--bg-navbar) !important;
  border-top: 2px solid var(--accent-gold) !important;
  color: var(--text-secondary) !important;
  text-align: center !important;
  padding: var(--spacing-lg) !important;
  position: relative !important;
  overflow: hidden !important;
}

.main-footer::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent 0%, var(--accent-gold) 50%, transparent 100%) !important;
  opacity: 0.3 !important;
}

.main-footer strong {
  color: var(--accent-gold) !important;
  font-weight: 600 !important;
}

.main-footer a {
  color: var(--accent-gold) !important;
  text-decoration: none !important;
  transition: all var(--transition-fast) ease !important;
}

.main-footer a:hover {
  color: var(--accent-gold-hover) !important;
  text-decoration: underline !important;
}

.main-footer .float-right {
  color: var(--text-primary) !important;
}

.main-footer .float-right b {
  color: var(--accent-gold) !important;
}

/* Barras de rolagem ultra-discretas - quase invisíveis */
.main-sidebar::-webkit-scrollbar,
.content-wrapper::-webkit-scrollbar,
.table-responsive::-webkit-scrollbar,
.modal-body::-webkit-scrollbar,
body::-webkit-scrollbar {
  width: 1px !important;
  height: 1px !important;
}

.main-sidebar::-webkit-scrollbar-track,
.content-wrapper::-webkit-scrollbar-track,
.table-responsive::-webkit-scrollbar-track,
.modal-body::-webkit-scrollbar-track,
body::-webkit-scrollbar-track {
  background: transparent !important;
}

.main-sidebar::-webkit-scrollbar-thumb,
.content-wrapper::-webkit-scrollbar-thumb,
.table-responsive::-webkit-scrollbar-thumb,
.modal-body::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb {
  background-color: rgba(212, 175, 55, 0.1) !important;
  border-radius: 1px !important;
}

.main-sidebar::-webkit-scrollbar-thumb:hover,
.content-wrapper::-webkit-scrollbar-thumb:hover,
.table-responsive::-webkit-scrollbar-thumb:hover,
.modal-body::-webkit-scrollbar-thumb:hover,
body::-webkit-scrollbar-thumb:hover {
  background-color: rgba(212, 175, 55, 0.2) !important;
}

/* Firefox scrollbar ultra-discreto */
.main-sidebar,
.content-wrapper,
.table-responsive,
.modal-body,
body {
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

/* =============================================
   DASHBOARD PROFISSIONAL - DESIGN PREMIUM
   ============================================= */

/* Cabeçalho profissional da dashboard */
.dashboard-header {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  color: white !important;
  border-radius: 15px !important;
  box-shadow: 0 10px 30px rgba(102, 126, 234, 0.3) !important;
  margin-bottom: 2rem !important;
  position: relative !important;
  overflow: hidden !important;
}

.dashboard-header::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.05)"/><circle cx="50" cy="10" r="0.5" fill="rgba(255,255,255,0.08)"/><circle cx="10" cy="60" r="0.5" fill="rgba(255,255,255,0.08)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>') !important;
  opacity: 0.3 !important;
}

.dashboard-header .display-4 {
  font-weight: 700 !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
  position: relative !important;
  z-index: 2 !important;
}

.dashboard-header .lead {
  font-size: 1.2rem !important;
  opacity: 0.9 !important;
  position: relative !important;
  z-index: 2 !important;
}

.dashboard-header .fa-chart-line {
  position: relative !important;
  z-index: 2 !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1)) !important;
}

/* Cards de estatísticas melhorados */
.info-box {
  border-radius: 15px !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important;
  position: relative !important;
  overflow: hidden !important;
}

.info-box::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background: rgba(255, 255, 255, 0.3) !important;
}

.info-box:hover {
  transform: translateY(-5px) scale(1.02) !important;
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.15) !important;
}

.info-box-icon {
  border-radius: 50% !important;
  width: 70px !important;
  height: 70px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.8rem !important;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2) !important;
}

.info-box-content {
  padding: 1.5rem !important;
}

.info-box-number {
  font-size: 2rem !important;
  font-weight: 700 !important;
  margin-bottom: 0.5rem !important;
}

.info-box-text {
  font-size: 0.9rem !important;
  opacity: 0.8 !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
}

/* Cards das tabelas de vencimentos */
.expiration-card {
  border-radius: 12px !important;
  overflow: hidden !important;
  transition: all 0.3s ease !important;
}

.expiration-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15) !important;
}

.expiration-card .card-header {
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%) !important;
  border: none !important;
  padding: 1rem 1.5rem !important;
}

.expiration-card .table {
  margin-bottom: 0 !important;
}

.expiration-card .table th {
  background: #f8f9fa !important;
  border-top: none !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.5px !important;
  padding: 1rem 0.75rem !important;
}

.expiration-card .table td {
  padding: 0.75rem !important;
  vertical-align: middle !important;
}

/* Cards financeiros */
.financial-card {
  border-radius: 15px !important;
  overflow: hidden !important;
  transition: all 0.3s ease !important;
  position: relative !important;
}

.financial-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: linear-gradient(45deg, rgba(255,255,255,0.1) 0%, transparent 100%) !important;
  pointer-events: none !important;
}

.financial-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15) !important;
}

.financial-card .card-body {
  padding: 2rem !important;
  text-align: center !important;
}

.financial-card .fa-3x {
  margin-bottom: 1rem !important;
  opacity: 0.9 !important;
}

.financial-card .card-title {
  font-size: 1.1rem !important;
  font-weight: 600 !important;
  margin-bottom: 1rem !important;
}

.financial-card h2 {
  font-size: 2.5rem !important;
  font-weight: 700 !important;
  margin-bottom: 0.5rem !important;
}

/* Cards de ações rápidas */
.action-card {
  border-radius: 12px !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
}

.action-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15) !important;
}

.action-card .card-body {
  text-align: center !important;
  padding: 1.5rem !important;
}

.action-card .fa-2x {
  margin-bottom: 1rem !important;
  opacity: 0.8 !important;
  transition: all 0.3s ease !important;
}

.action-card:hover .fa-2x {
  transform: scale(1.1) !important;
  opacity: 1 !important;
}

.action-card h6 {
  font-weight: 600 !important;
  margin-bottom: 0.5rem !important;
}

.action-card .btn {
  margin-top: 1rem !important;
  transition: all 0.3s ease !important;
}

.action-card .btn:hover {
  transform: translateY(-2px) !important;
}

/* Cards de status do sistema */
.status-card {
  border-radius: 10px !important;
  transition: all 0.3s ease !important;
}

.status-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important;
}

.status-card .card-body {
  text-align: center !important;
  padding: 1.5rem !important;
}

.status-card .fa-2x {
  margin-bottom: 1rem !important;
  opacity: 0.8 !important;
}

.status-card .badge {
  font-size: 0.8rem !important;
  padding: 0.5rem 1rem !important;
}

/* Animações específicas para dashboard */
@keyframes slideInFromLeft {
  from {
    opacity: 0;
    transform: translateX(-50px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideInFromRight {
  from {
    opacity: 0;
    transform: translateX(50px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeInScale {
  from {
    opacity: 0;
    transform: scale(0.9);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.priority-card,
.info-box,
.financial-card,
.action-card,
.status-card {
  animation: fadeInScale 0.6s ease-out !important;
}

.priority-card:nth-child(1) { animation-delay: 0.1s !important; }
.priority-card:nth-child(2) { animation-delay: 0.2s !important; }
.priority-card:nth-child(3) { animation-delay: 0.3s !important; }
.priority-card:nth-child(4) { animation-delay: 0.4s !important; }

/* Melhorando a responsividade da dashboard */
@media (max-width: 768px) {
  .dashboard-header {
    padding: 1.5rem !important;
    text-align: center !important;
  }

  .dashboard-header .col-md-8,
  .dashboard-header .col-md-4 {
    margin-bottom: 1rem !important;
  }

  .info-box {
    margin-bottom: 1rem !important;
  }

  .financial-card .card-body {
    padding: 1.5rem !important;
  }

  .financial-card h2 {
    font-size: 2rem !important;
  }

  .action-card {
    margin-bottom: 1rem !important;
  }
}

/* Indicadores visuais para diferentes tipos de dados */
.iptv-indicator {
  position: relative !important;
}

.iptv-indicator::after {
  content: '📺' !important;
  position: absolute !important;
  top: -5px !important;
  right: -5px !important;
  font-size: 0.8rem !important;
  opacity: 0.7 !important;
}

.p2p-indicator {
  position: relative !important;
}

.p2p-indicator::after {
  content: '🔗' !important;
  position: absolute !important;
  top: -5px !important;
  right: -5px !important;
  font-size: 0.8rem !important;
  opacity: 0.7 !important;
}

/* Melhorando a experiência visual */
.table-hover tbody tr:hover {
  background-color: rgba(102, 126, 234, 0.05) !important;
  transform: scale(1.01) !important;
  transition: all 0.2s ease !important;
}

/* Estilos para badges personalizados */
.badge-custom {
  font-size: 0.7rem !important;
  padding: 0.4rem 0.8rem !important;
  border-radius: 20px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

/* Área de informações do sistema */
.system-info-card {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  border-radius: 8px !important;
}

.system-info-card .card-body {
  padding: 1.5rem !important;
}

/* Responsividade aprimorada */
@media (max-width: 1200px) {
  .info-box-number {
    font-size: 1.8rem !important;
  }

  .financial-card h2 {
    font-size: 2.2rem !important;
  }
}

/* =============================================
   MELHORIAS ESPECÍFICAS PARA TABELAS DE DASHBOARD
   ============================================= */

/* Tabelas de vencimentos melhoradas */
.dashboard-expiration-table {
  border-radius: 8px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
}

.dashboard-expiration-table thead th {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  border: none !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  padding: 1rem 0.75rem !important;
  position: relative !important;
}

.dashboard-expiration-table thead th i {
  opacity: 0.7 !important;
  margin-right: 0.5rem !important;
}

.dashboard-expiration-table tbody tr {
  transition: all 0.2s ease !important;
  border-bottom: 1px solid #f1f3f4 !important;
}

.dashboard-expiration-table tbody tr:hover {
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.05) 0%, rgba(102, 126, 234, 0.02) 100%) !important;
  transform: scale(1.01) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
}

.dashboard-expiration-table tbody td {
  padding: 0.875rem 0.75rem !important;
  vertical-align: middle !important;
  border: none !important;
  font-size: 0.9rem !important;
}

/* Indicadores de urgência nas tabelas */
.urgency-indicator {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.25rem !important;
  padding: 0.25rem 0.5rem !important;
  border-radius: 12px !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

.urgency-critical {
  background: linear-gradient(135deg, #dc3545 0%, #c82333 100%) !important;
  color: white !important;
}

.urgency-warning {
  background: linear-gradient(135deg, #ffc107 0%, #e0a800 100%) !important;
  color: #212529 !important;
}

.urgency-info {
  background: linear-gradient(135deg, #17a2b8 0%, #138496 100%) !important;
  color: white !important;
}

.urgency-safe {
  background: linear-gradient(135deg, #28a745 0%, #218838 100%) !important;
  color: white !important;
}

/* Botões de ação nas tabelas */
.table-action-btn {
  padding: 0.375rem 0.75rem !important;
  font-size: 0.75rem !important;
  border-radius: 6px !important;
  border: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.25rem !important;
  font-weight: 500 !important;
}

.table-action-btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
}

.table-action-btn i {
  font-size: 0.7rem !important;
}

/* Área de informações das tabelas */
.table-info-footer {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  border-top: 1px solid #dee2e6 !important;
  padding: 0.75rem 1rem !important;
  text-align: center !important;
  font-size: 0.8rem !important;
  color: #6c757d !important;
}

.table-info-footer i {
  opacity: 0.7 !important;
}

/* Cards de informações financeiras melhorados */
.financial-info-card {
  position: relative !important;
  overflow: hidden !important;
}

.financial-info-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 100%) !important;
  pointer-events: none !important;
}

.financial-info-card .card-body {
  position: relative !important;
  z-index: 2 !important;
}

/* Responsividade aprimorada para tabelas */
@media (max-width: 768px) {
  .dashboard-expiration-table {
    font-size: 0.8rem !important;
  }

  .dashboard-expiration-table th,
  .dashboard-expiration-table td {
    padding: 0.5rem !important;
  }

  .table-action-btn {
    padding: 0.25rem 0.5rem !important;
    font-size: 0.7rem !important;
  }

  .table-info-footer {
    padding: 0.5rem !important;
    font-size: 0.75rem !important;
  }
}

/* Animação de carregamento melhorada */
.table-loading {
  position: relative !important;
}

.table-loading::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: rgba(255, 255, 255, 0.8) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 10 !important;
}

.table-loading::before {
  content: 'Carregando...' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  background: #007bff !important;
  color: white !important;
  padding: 0.5rem 1rem !important;
  border-radius: 20px !important;
  z-index: 11 !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  box-shadow: 0 2px 10px rgba(0, 123, 255, 0.3) !important;
  animation: pulse-loading 1.5s infinite !important;
}

@keyframes pulse-loading {
  0% { opacity: 0.7; transform: translate(-50%, -50%) scale(1); }
  50% { opacity: 1; transform: translate(-50%, -50%) scale(1.05); }
  100% { opacity: 0.7; transform: translate(-50%, -50%) scale(1); }
}

/* Melhorando a apresentação dos dados financeiros */
.credits-display {
  font-family: 'Courier New', monospace !important;
  font-size: 2.2rem !important;
  font-weight: 700 !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
  position: relative !important;
}

.credits-display::before {
  content: 'R$' !important;
  position: absolute !important;
  left: -2rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 1rem !important;
  opacity: 0.7 !important;
  font-weight: 400 !important;
}

/* Área de ações rápidas melhorada */
.quick-actions-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
  gap: 1rem !important;
}

@media (max-width: 768px) {
  .quick-actions-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Melhorando a apresentação dos cards de ações */
.action-card-enhanced {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  border: 1px solid #dee2e6 !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative !important;
  overflow: hidden !important;
}

.action-card-enhanced::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, #007bff, #28a745, #ffc107, #dc3545) !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
}

.action-card-enhanced:hover::before {
  opacity: 1 !important;
}

.action-card-enhanced:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15) !important;
  border-color: #007bff !important;
}

/* Sistema de notificações aprimorado */
.notification-badge {
  position: absolute !important;
  top: -5px !important;
  right: -5px !important;
  background: linear-gradient(135deg, #dc3545 0%, #c82333 100%) !important;
  color: white !important;
  border-radius: 50% !important;
  width: 20px !important;
  height: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 8px rgba(220, 53, 69, 0.4) !important;
  animation: pulse-notification 2s infinite !important;
}

/* =============================================
   TABELAS DE VENCIMENTOS - DESIGN ULTRA PREMIUM
   ============================================= */

/* Tabelas aprimoradas com sistema de cores inteligente */
.enhanced-expiration-table {
  border-radius: 15px !important;
  overflow: hidden !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12) !important;
  background: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  backdrop-filter: blur(10px) !important;
  position: relative !important;
}

.enhanced-expiration-table::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(102, 126, 234, 0.3), transparent) !important;
}

/* Modo escuro - esquema de cinzas sofisticado */
.dark-mode .enhanced-expiration-table {
  background: linear-gradient(135deg, #2d3748 0%, #1a202c 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3) !important;
}

.dark-mode .enhanced-expiration-table::before {
  background: linear-gradient(90deg, transparent, rgba(102, 126, 234, 0.2), transparent) !important;
}

/* Cabeçalhos premium com glassmorphism */
.enhanced-expiration-table thead th {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  color: white !important;
  border: none !important;
  font-weight: 700 !important;
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  padding: 1.5rem 1.25rem !important;
  position: relative !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
  backdrop-filter: blur(10px) !important;
}

.enhanced-expiration-table thead th::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent) !important;
}

.enhanced-expiration-table thead th i {
  opacity: 0.95 !important;
  margin-right: 0.75rem !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2)) !important;
  font-size: 1rem !important;
}

/* =============================================
   MODO DARK - DESTAQUE ULTRA MÁXIMO DO TEXTO
   ============================================= */

/* Textos das células com contraste ULTRA MÁXIMO no modo dark */
.dark-mode .enhanced-expiration-table tbody td {
  color: #ffffff !important;
  font-weight: 600 !important;
  text-shadow:
    0 2px 4px rgba(0, 0, 0, 0.8),
    0 1px 2px rgba(0, 0, 0, 0.6) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.02) 0%, rgba(255, 255, 255, 0.01) 100%) !important;
}

/* Nome do cliente ULTRA destacado no modo dark */
.dark-mode .enhanced-expiration-table tbody td:first-child {
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 1rem !important;
  text-shadow:
    0 3px 6px rgba(0, 0, 0, 0.9),
    0 2px 4px rgba(0, 0, 0, 0.7),
    0 1px 2px rgba(0, 0, 0, 0.5) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.04) 100%) !important;
  border-radius: 12px !important;
  padding: 1.25rem 1.5rem !important;
  margin: 0.5rem 0 !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1) !important;
}

/* Revendedor com destaque forte no modo dark */
.dark-mode .enhanced-expiration-table tbody td:nth-child(3) {
  color: #f0f4f8 !important;
  font-weight: 700 !important;
  font-style: italic !important;
  text-shadow:
    0 2px 4px rgba(0, 0, 0, 0.7),
    0 1px 2px rgba(0, 0, 0, 0.5) !important;
}

/* Ações com destaque médio no modo dark */
.dark-mode .enhanced-expiration-table tbody td:last-child {
  color: #e2e8f0 !important;
  font-weight: 600 !important;
  text-shadow:
    0 2px 4px rgba(0, 0, 0, 0.6),
    0 1px 2px rgba(0, 0, 0, 0.4) !important;
}

/* Hover effects com texto ULTRA branco no modo dark */
.dark-mode .enhanced-expiration-table tbody tr:hover td {
  color: #ffffff !important;
  font-weight: 700 !important;
  text-shadow:
    0 3px 8px rgba(0, 0, 0, 0.9),
    0 2px 4px rgba(0, 0, 0, 0.7) !important;
}

.dark-mode .enhanced-expiration-table tbody tr:hover td:first-child {
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 1.05rem !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.15) 0%, rgba(255, 255, 255, 0.08) 100%) !important;
  text-shadow:
    0 4px 10px rgba(0, 0, 0, 1),
    0 2px 6px rgba(0, 0, 0, 0.8) !important;
}

/* Cabeçalhos com texto ultra branco no modo dark */
.dark-mode .enhanced-expiration-table thead th {
  background: linear-gradient(135deg, #2d3748 0%, #1a202c 100%) !important;
  color: #ffffff !important;
  text-shadow:
    0 3px 6px rgba(0, 0, 0, 0.8),
    0 2px 4px rgba(0, 0, 0, 0.6) !important;
  border-bottom: 3px solid #90cdf4 !important;
  font-weight: 800 !important;
  letter-spacing: 1.5px !important;
}

/* Área de informações com texto MÁXIMO branco no modo dark */
.dark-mode .table-info-footer-enhanced {
  background: linear-gradient(135deg, rgba(26, 32, 44, 0.99) 0%, rgba(45, 55, 72, 0.99) 100%) !important;
  border-top: 5px solid #bee3f8 !important;
  border-radius: 0 0 25px 25px !important;
  backdrop-filter: blur(30px) !important;
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, 0.15),
    0 20px 60px rgba(0, 0, 0, 0.7) !important;
}

.dark-mode .table-info-footer-enhanced::before {
  background: linear-gradient(90deg, transparent, #bee3f8, transparent) !important;
  opacity: 1 !important;
  height: 3px !important;
}

.dark-mode .table-info-footer-enhanced span {
  color: #ffffff !important;
  font-weight: 800 !important;
  font-size: 1rem !important;
  text-shadow:
    0 3px 6px rgba(0, 0, 0, 0.8),
    0 2px 4px rgba(0, 0, 0, 0.6),
    0 1px 2px rgba(0, 0, 0, 0.4) !important;
  line-height: 1.5 !important;
}

.dark-mode .table-info-footer-enhanced i {
  color: #bee3f8 !important;
  font-size: 1.2rem !important;
  filter: drop-shadow(0 3px 6px rgba(190, 227, 248, 0.6)) !important;
  animation: infoIconPulse 1.5s ease-in-out infinite !important;
}

@keyframes infoIconPulse {
  0%, 100% {
    transform: scale(1);
    filter: drop-shadow(0 3px 6px rgba(190, 227, 248, 0.6));
  }
  50% {
    transform: scale(1.15);
    filter: drop-shadow(0 5px 12px rgba(190, 227, 248, 0.8));
  }
}

/* Legenda com texto ULTRA branco no modo dark */
.dark-mode .legend-indicators {
  background: linear-gradient(135deg, rgba(16, 22, 34, 0.9) 0%, rgba(35, 45, 62, 0.9) 100%) !important;
  border: 2px solid rgba(255, 255, 255, 0.3) !important;
  backdrop-filter: blur(20px) !important;
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.6),
    inset 0 1px 0 rgba(255, 255, 255, 0.1) !important;
}

.dark-mode .legend-indicators .urgency-indicator {
  background: linear-gradient(135deg, rgba(190, 227, 248, 0.3) 0%, rgba(255, 255, 255, 0.15) 100%) !important;
  color: #ffffff !important;
  border: 3px solid #bee3f8 !important;
  font-weight: 900 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  text-shadow:
    0 3px 6px rgba(0, 0, 0, 0.8),
    0 2px 4px rgba(0, 0, 0, 0.6) !important;
  backdrop-filter: blur(25px) !important;
  box-shadow:
    0 6px 20px rgba(190, 227, 248, 0.4),
    inset 0 2px 0 rgba(255, 255, 255, 0.3),
    inset 0 -1px 0 rgba(0, 0, 0, 0.2) !important;
  padding: 0.75rem 1.25rem !important;
  border-radius: 25px !important;
}

/* Estados vazios com texto MÁXIMO branco no modo dark */
.dark-mode .empty-table-state {
  background: linear-gradient(135deg, rgba(35, 45, 62, 0.98) 0%, rgba(16, 22, 34, 0.98) 100%) !important;
  border: 3px solid rgba(190, 227, 248, 0.4) !important;
  border-radius: 25px !important;
  backdrop-filter: blur(25px) !important;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.7),
    inset 0 2px 0 rgba(255, 255, 255, 0.15) !important;
}

.dark-mode .empty-table-state::before {
  background: linear-gradient(90deg, transparent, #bee3f8, transparent) !important;
  height: 4px !important;
}

.dark-mode .empty-table-state i {
  color: #bee3f8 !important;
  font-size: 6rem !important;
  margin-bottom: 2.5rem !important;
  filter: drop-shadow(0 6px 12px rgba(190, 227, 248, 0.5)) !important;
  animation: float 3s ease-in-out infinite !important;
}

.dark-mode .empty-table-state h5 {
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 1.5rem !important;
  text-shadow:
    0 4px 8px rgba(0, 0, 0, 0.9),
    0 3px 6px rgba(0, 0, 0, 0.7),
    0 2px 4px rgba(0, 0, 0, 0.5) !important;
  margin-bottom: 1.5rem !important;
}

.dark-mode .empty-table-state p {
  color: #f0f4f8 !important;
  font-weight: 700 !important;
  font-size: 1.1rem !important;
  text-shadow:
    0 3px 6px rgba(0, 0, 0, 0.7),
    0 2px 4px rgba(0, 0, 0, 0.5) !important;
  line-height: 1.8 !important;
  max-width: 600px !important;
}

/* Cards de informações com texto ULTRA branco no modo dark */
.dark-mode .table-info-card {
  background: linear-gradient(135deg, rgba(35, 45, 62, 0.99) 0%, rgba(16, 22, 34, 0.99) 100%) !important;
  border: 3px solid rgba(190, 227, 248, 0.5) !important;
  border-radius: 25px !important;
  backdrop-filter: blur(35px) !important;
  box-shadow:
    0 25px 75px rgba(0, 0, 0, 0.8),
    inset 0 2px 0 rgba(255, 255, 255, 0.2) !important;
}

.dark-mode .table-info-card::before {
  background: linear-gradient(90deg, transparent, #bee3f8, transparent) !important;
  height: 4px !important;
}

.dark-mode .table-info-card .info-header {
  border-bottom: 3px solid rgba(190, 227, 248, 0.4) !important;
  padding-bottom: 1.5rem !important;
}

.dark-mode .table-info-card .info-header i {
  color: #bee3f8 !important;
  font-size: 1.8rem !important;
  filter: drop-shadow(0 4px 8px rgba(190, 227, 248, 0.6)) !important;
  animation: headerIconGlow 2s ease-in-out infinite !important;
}

@keyframes headerIconGlow {
  0%, 100% {
    filter: drop-shadow(0 4px 8px rgba(190, 227, 248, 0.6));
    transform: scale(1);
  }
  50% {
    filter: drop-shadow(0 6px 15px rgba(190, 227, 248, 0.8));
    transform: scale(1.1);
  }
}

.dark-mode .table-info-card .info-header h6 {
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 1.3rem !important;
  text-shadow:
    0 3px 6px rgba(0, 0, 0, 0.8),
    0 2px 4px rgba(0, 0, 0, 0.6) !important;
}

/* Área de estatísticas com texto MÁXIMO branco no modo dark */
.dark-mode .table-stats {
  background: linear-gradient(135deg, rgba(35, 45, 62, 0.95) 0%, rgba(16, 22, 34, 0.95) 100%) !important;
  border: 3px solid rgba(190, 227, 248, 0.4) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(25px) !important;
  box-shadow:
    0 15px 40px rgba(0, 0, 0, 0.6),
    inset 0 2px 0 rgba(255, 255, 255, 0.15) !important;
  padding: 2rem !important;
  margin: 2rem 0 !important;
}

.dark-mode .table-stat {
  background: linear-gradient(135deg, rgba(190, 227, 248, 0.15) 0%, rgba(255, 255, 255, 0.08) 100%) !important;
  border: 2px solid rgba(190, 227, 248, 0.3) !important;
  border-radius: 15px !important;
  padding: 1rem !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.dark-mode .table-stat:hover {
  background: linear-gradient(135deg, rgba(190, 227, 248, 0.2) 0%, rgba(255, 255, 255, 0.12) 100%) !important;
  border-color: rgba(190, 227, 248, 0.5) !important;
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow:
    0 10px 30px rgba(190, 227, 248, 0.3),
    inset 0 2px 0 rgba(255, 255, 255, 0.2) !important;
}

.dark-mode .table-stat-number {
  color: #bee3f8 !important;
  font-weight: 900 !important;
  font-size: 2rem !important;
  text-shadow:
    0 4px 8px rgba(190, 227, 248, 0.5),
    0 3px 6px rgba(0, 0, 0, 0.8) !important;
  margin-bottom: 0.75rem !important;
}

.dark-mode .table-stat-label {
  color: #f0f4f8 !important;
  font-weight: 800 !important;
  font-size: 0.9rem !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  text-shadow:
    0 3px 6px rgba(0, 0, 0, 0.7),
    0 2px 4px rgba(0, 0, 0, 0.5) !important;
}

/* Datas com texto ultra destacado no modo dark */
.dark-mode .expiration-date .date-text {
  color: #ffffff !important;
  font-weight: 700 !important;
  text-shadow:
    0 2px 4px rgba(0, 0, 0, 0.8),
    0 1px 2px rgba(0, 0, 0, 0.6) !important;
}

.dark-mode .expiration-date .days-count {
  color: #e2e8f0 !important;
  font-weight: 600 !important;
  text-shadow:
    0 2px 4px rgba(0, 0, 0, 0.6),
    0 1px 2px rgba(0, 0, 0, 0.4) !important;
}

/* Área de informações com textos mais destacados no modo dark */
.dark-mode .table-info-footer-enhanced {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.98) 0%, rgba(26, 32, 44, 0.98) 100%) !important;
  border-top: 3px solid #63b3ed !important;
  backdrop-filter: blur(20px) !important;
}

.dark-mode .table-info-footer-enhanced span {
  color: #f7fafc !important;
  font-weight: 600 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4) !important;
}

.dark-mode .table-info-footer-enhanced i {
  color: #90cdf4 !important;
  filter: drop-shadow(0 2px 4px rgba(144, 205, 244, 0.4)) !important;
}

/* Legenda com cores mais vibrantes no modo dark */
.dark-mode .legend-indicators .urgency-indicator {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.9) 0%, rgba(26, 32, 44, 0.9) 100%) !important;
  color: #f7fafc !important;
  border: 1px solid rgba(255, 255, 255, 0.25) !important;
  font-weight: 700 !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5) !important;
  backdrop-filter: blur(15px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
}

/* Estados vazios com textos mais legíveis no modo dark */
.dark-mode .empty-table-state {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.9) 0%, rgba(26, 32, 44, 0.9) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  color: #e2e8f0 !important;
  backdrop-filter: blur(15px) !important;
}

.dark-mode .empty-table-state h5 {
  color: #ffffff !important;
  font-weight: 700 !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5) !important;
}

.dark-mode .empty-table-state p {
  color: #cbd5e0 !important;
  font-weight: 500 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
}

/* Linhas da tabela com efeitos avançados */
.enhanced-expiration-table tbody tr {
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  border-bottom: 1px solid rgba(102, 126, 234, 0.08) !important;
  position: relative !important;
  backdrop-filter: blur(5px) !important;
}

.enhanced-expiration-table tbody tr:hover {
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.12) 0%, rgba(118, 75, 162, 0.08) 100%) !important;
  transform: translateY(-3px) scale(1.015) !important;
  box-shadow: 0 12px 40px rgba(102, 126, 234, 0.2) !important;
  border-left: 4px solid #667eea !important;
  backdrop-filter: blur(10px) !important;
}

.enhanced-expiration-table tbody td {
  padding: 1.25rem 1rem !important;
  vertical-align: middle !important;
  border: none !important;
  font-size: 0.9rem !important;
  position: relative !important;
  transition: all 0.3s ease !important;
}

/* Modo escuro - linhas da tabela com melhor legibilidade */
.dark-mode .enhanced-expiration-table tbody td {
  color: #e2e8f0 !important;
  font-weight: 500 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
}

/* Destaque especial para nomes de clientes no modo dark */
.dark-mode .enhanced-expiration-table tbody td:first-child {
  color: #f7fafc !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4) !important;
}

/* Melhor contraste para datas no modo dark */
.dark-mode .expiration-date .date-text {
  color: #f7fafc !important;
  font-weight: 600 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
}

.dark-mode .expiration-date .days-count {
  color: #cbd5e0 !important;
  font-weight: 500 !important;
}

/* Área de informações com destaque máximo no modo dark */
.dark-mode .table-info-footer-enhanced {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.98) 0%, rgba(26, 32, 44, 0.98) 100%) !important;
  border-top: 4px solid #90cdf4 !important;
  border-radius: 0 0 20px 20px !important;
  backdrop-filter: blur(25px) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 15px 50px rgba(0, 0, 0, 0.5) !important;
  position: relative !important;
  overflow: hidden !important;
}

.dark-mode .table-info-footer-enhanced::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, #90cdf4, transparent) !important;
  opacity: 0.8 !important;
}

.dark-mode .table-info-footer-enhanced .d-flex {
  align-items: center !important;
  position: relative !important;
  z-index: 2 !important;
}

.dark-mode .table-info-footer-enhanced span {
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
  line-height: 1.4 !important;
}

.dark-mode .table-info-footer-enhanced i {
  color: #90cdf4 !important;
  font-size: 1.1rem !important;
  filter: drop-shadow(0 2px 4px rgba(144, 205, 244, 0.5)) !important;
  animation: infoIconPulse 2s ease-in-out infinite !important;
}

@keyframes infoIconPulse {
  0%, 100% {
    transform: scale(1);
    filter: drop-shadow(0 2px 4px rgba(144, 205, 244, 0.5));
  }
  50% {
    transform: scale(1.1);
    filter: drop-shadow(0 4px 8px rgba(144, 205, 244, 0.7));
  }
}

/* Legenda ultra destacada no modo dark */
.dark-mode .legend-indicators {
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  padding: 0.75rem 1rem !important;
  background: linear-gradient(135deg, rgba(26, 32, 44, 0.8) 0%, rgba(45, 55, 72, 0.8) 100%) !important;
  border-radius: 15px !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  backdrop-filter: blur(15px) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.4) !important;
  margin-top: 0.5rem !important;
}

.dark-mode .legend-indicators .urgency-indicator {
  background: linear-gradient(135deg, rgba(144, 205, 244, 0.2) 0%, rgba(255, 255, 255, 0.1) 100%) !important;
  color: #ffffff !important;
  border: 2px solid #90cdf4 !important;
  font-weight: 800 !important;
  font-size: 0.75rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
  backdrop-filter: blur(20px) !important;
  box-shadow:
    0 4px 15px rgba(144, 205, 244, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
  padding: 0.5rem 1rem !important;
  border-radius: 20px !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative !important;
  overflow: hidden !important;
}

.dark-mode .legend-indicators .urgency-indicator::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent) !important;
  transition: left 0.5s ease !important;
}

.dark-mode .legend-indicators .urgency-indicator:hover::before {
  left: 100% !important;
}

.dark-mode .legend-indicators .urgency-indicator:hover {
  transform: translateY(-2px) scale(1.05) !important;
  box-shadow:
    0 8px 25px rgba(144, 205, 244, 0.4),
    inset 0 2px 0 rgba(255, 255, 255, 0.3) !important;
  border-color: #bee3f8 !important;
}

/* Estados vazios ultra visíveis no modo dark */
.dark-mode .empty-table-state {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.95) 0%, rgba(26, 32, 44, 0.95) 100%) !important;
  border: 2px solid rgba(144, 205, 244, 0.3) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(20px) !important;
  box-shadow:
    0 15px 50px rgba(0, 0, 0, 0.5),
    inset 0 1px 0 rgba(255, 255, 255, 0.1) !important;
  position: relative !important;
  overflow: hidden !important;
}

.dark-mode .empty-table-state::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, transparent, #90cdf4, transparent) !important;
}

.dark-mode .empty-table-state i {
  color: #90cdf4 !important;
  font-size: 5rem !important;
  margin-bottom: 2rem !important;
  filter: drop-shadow(0 4px 8px rgba(144, 205, 244, 0.4)) !important;
  animation: float 4s ease-in-out infinite !important;
}

.dark-mode .empty-table-state h5 {
  color: #ffffff !important;
  font-weight: 800 !important;
  font-size: 1.25rem !important;
  text-shadow: 0 3px 6px rgba(0, 0, 0, 0.7) !important;
  margin-bottom: 1rem !important;
}

.dark-mode .empty-table-state p {
  color: #e2e8f0 !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5) !important;
  line-height: 1.6 !important;
  max-width: 500px !important;
}

/* Cards de informações com máximo destaque no modo dark */
.dark-mode .table-info-card {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.98) 0%, rgba(26, 32, 44, 0.98) 100%) !important;
  border: 2px solid rgba(144, 205, 244, 0.4) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(30px) !important;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.6),
    inset 0 1px 0 rgba(255, 255, 255, 0.15) !important;
  position: relative !important;
  overflow: hidden !important;
}

.dark-mode .table-info-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, transparent, #90cdf4, transparent) !important;
}

.dark-mode .table-info-card .info-header {
  border-bottom: 2px solid rgba(144, 205, 244, 0.3) !important;
  padding-bottom: 1rem !important;
}

.dark-mode .table-info-card .info-header i {
  color: #90cdf4 !important;
  font-size: 1.5rem !important;
  filter: drop-shadow(0 3px 6px rgba(144, 205, 244, 0.5)) !important;
  animation: headerIconGlow 3s ease-in-out infinite !important;
}

@keyframes headerIconGlow {
  0%, 100% {
    filter: drop-shadow(0 3px 6px rgba(144, 205, 244, 0.5));
  }
  50% {
    filter: drop-shadow(0 5px 10px rgba(144, 205, 244, 0.7));
  }
}

.dark-mode .table-info-card .info-header h6 {
  color: #ffffff !important;
  font-weight: 800 !important;
  font-size: 1.1rem !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
}

/* Área de estatísticas com destaque premium no modo dark */
.dark-mode .table-stats {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.9) 0%, rgba(26, 32, 44, 0.9) 100%) !important;
  border: 2px solid rgba(144, 205, 244, 0.3) !important;
  border-radius: 15px !important;
  backdrop-filter: blur(20px) !important;
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.1) !important;
  padding: 1.5rem !important;
  margin: 1.5rem 0 !important;
}

.dark-mode .table-stat {
  text-align: center !important;
  padding: 0.75rem !important;
  border-radius: 10px !important;
  background: linear-gradient(135deg, rgba(144, 205, 244, 0.1) 0%, rgba(255, 255, 255, 0.05) 100%) !important;
  border: 1px solid rgba(144, 205, 244, 0.2) !important;
  transition: all 0.3s ease !important;
}

.dark-mode .table-stat:hover {
  background: linear-gradient(135deg, rgba(144, 205, 244, 0.15) 0%, rgba(255, 255, 255, 0.08) 100%) !important;
  border-color: rgba(144, 205, 244, 0.4) !important;
  transform: translateY(-2px) !important;
}

.dark-mode .table-stat-number {
  color: #90cdf4 !important;
  font-weight: 800 !important;
  font-size: 1.75rem !important;
  text-shadow: 0 3px 6px rgba(144, 205, 244, 0.4) !important;
  margin-bottom: 0.5rem !important;
}

.dark-mode .table-stat-label {
  color: #e2e8f0 !important;
  font-weight: 700 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5) !important;
}

/* Indicadores de prioridade com melhor visibilidade no modo dark */
.dark-mode .priority-high {
  background: linear-gradient(135deg, #ff6b6b 0%, #ee5a52 100%) !important;
  box-shadow: 0 0 15px rgba(255, 107, 107, 0.6) !important;
}

.dark-mode .priority-medium {
  background: linear-gradient(135deg, #ffd93d 0%, #ffbe0b 100%) !important;
  box-shadow: 0 0 15px rgba(255, 217, 61, 0.6) !important;
}

.dark-mode .priority-low {
  background: linear-gradient(135deg, #51cfef 0%, #4ecdc4 100%) !important;
  box-shadow: 0 0 15px rgba(81, 207, 239, 0.6) !important;
}

/* Sistema avançado de indicadores de urgência com glassmorphism */
.urgency-critical-row {
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.08) 0%, rgba(220, 53, 69, 0.03) 100%) !important;
  border-left: 5px solid #dc3545 !important;
  backdrop-filter: blur(5px) !important;
}

.urgency-critical-row:hover {
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.15) 0%, rgba(220, 53, 69, 0.08) 100%) !important;
  box-shadow: 0 12px 40px rgba(220, 53, 69, 0.25) !important;
  border-left: 5px solid #ff6b6b !important;
}

.urgency-warning-row {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.08) 0%, rgba(255, 193, 7, 0.03) 100%) !important;
  border-left: 5px solid #ffc107 !important;
  backdrop-filter: blur(5px) !important;
}

.urgency-warning-row:hover {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.15) 0%, rgba(255, 193, 7, 0.08) 100%) !important;
  box-shadow: 0 12px 40px rgba(255, 193, 7, 0.25) !important;
  border-left: 5px solid #ffd93d !important;
}

.urgency-info-row {
  background: linear-gradient(135deg, rgba(23, 162, 184, 0.08) 0%, rgba(23, 162, 184, 0.03) 100%) !important;
  border-left: 5px solid #17a2b8 !important;
  backdrop-filter: blur(5px) !important;
}

.urgency-info-row:hover {
  background: linear-gradient(135deg, rgba(23, 162, 184, 0.15) 0%, rgba(23, 162, 184, 0.08) 100%) !important;
  box-shadow: 0 12px 40px rgba(23, 162, 184, 0.25) !important;
  border-left: 5px solid #51cfef !important;
}

/* Modo escuro - indicadores de urgência */
.dark-mode .urgency-critical-row {
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.12) 0%, rgba(220, 53, 69, 0.05) 100%) !important;
  border-left: 5px solid #ff4757 !important;
}

.dark-mode .urgency-warning-row {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.12) 0%, rgba(255, 193, 7, 0.05) 100%) !important;
  border-left: 5px solid #ffa502 !important;
}

.dark-mode .urgency-info-row {
  background: linear-gradient(135deg, rgba(23, 162, 184, 0.12) 0%, rgba(23, 162, 184, 0.05) 100%) !important;
  border-left: 5px solid #3742fa !important;
}

/* Formatação especial para datas com glassmorphism */
.expiration-date {
  font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  padding: 0.75rem 1rem !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.8) 0%, rgba(233, 236, 239, 0.8) 100%) !important;
  border: 1px solid rgba(222, 226, 230, 0.5) !important;
  position: relative !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  backdrop-filter: blur(10px) !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1) !important;
}

.expiration-date::before {
  content: '📅' !important;
  position: absolute !important;
  left: 0.75rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  opacity: 0.8 !important;
  font-size: 0.9rem !important;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1)) !important;
}

.expiration-date:hover {
  transform: translateY(-2px) scale(1.05) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15) !important;
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.95) 0%, rgba(233, 236, 239, 0.95) 100%) !important;
}

.expiration-date .date-text {
  margin-left: 2rem !important;
  display: block !important;
  color: #495057 !important;
  font-weight: 500 !important;
}

.expiration-date .days-count {
  font-size: 0.75rem !important;
  opacity: 0.75 !important;
  margin-top: 0.25rem !important;
  color: #6c757d !important;
  font-weight: 400 !important;
}

/* Modo escuro - datas */
.dark-mode .expiration-date {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.8) 0%, rgba(26, 32, 44, 0.8) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2) !important;
}

.dark-mode .expiration-date:hover {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.95) 0%, rgba(26, 32, 44, 0.95) 100%) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3) !important;
}

.dark-mode .expiration-date .date-text {
  color: #e2e8f0 !important;
}

.dark-mode .expiration-date .days-count {
  color: #a0aec0 !important;
}

/* Área de informações aprimorada com glassmorphism */
.table-info-footer-enhanced {
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.9) 0%, rgba(233, 236, 239, 0.9) 100%) !important;
  border-top: 3px solid #667eea !important;
  padding: 1.25rem 1.75rem !important;
  margin-top: 1.5rem !important;
  border-radius: 0 0 15px 15px !important;
  backdrop-filter: blur(15px) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
  position: relative !important;
}

.table-info-footer-enhanced::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(102, 126, 234, 0.3), transparent) !important;
}

.table-info-footer-enhanced .d-flex {
  align-items: center !important;
}

.table-info-footer-enhanced i {
  color: #667eea !important;
  opacity: 0.9 !important;
  filter: drop-shadow(0 1px 2px rgba(102, 126, 234, 0.3)) !important;
}

.legend-indicators {
  display: flex !important;
  align-items: center !important;
  gap: 0.75rem !important;
}

.legend-indicators .urgency-indicator {
  font-size: 0.7rem !important;
  padding: 0.375rem 0.75rem !important;
  border-radius: 15px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  transition: all 0.3s ease !important;
  backdrop-filter: blur(5px) !important;
}

.legend-indicators .urgency-indicator:hover {
  transform: translateY(-1px) scale(1.05) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

/* Modo escuro - área de informações */
.dark-mode .table-info-footer-enhanced {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.9) 0%, rgba(26, 32, 44, 0.9) 100%) !important;
  border-top: 3px solid #4a5568 !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
}

.dark-mode .table-info-footer-enhanced i {
  color: #63b3ed !important;
}

.dark-mode .legend-indicators .urgency-indicator {
  backdrop-filter: blur(8px) !important;
}

/* Estados vazios das tabelas com design aprimorado */
.empty-table-state {
  text-align: center !important;
  padding: 4rem 2.5rem !important;
  color: #6c757d !important;
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.5) 0%, rgba(233, 236, 239, 0.5) 100%) !important;
  border-radius: 12px !important;
  backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.empty-table-state i {
  font-size: 4rem !important;
  margin-bottom: 1.5rem !important;
  opacity: 0.6 !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1)) !important;
  animation: float 3s ease-in-out infinite !important;
}

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}

.empty-table-state h5 {
  color: #495057 !important;
  margin-bottom: 0.75rem !important;
  font-weight: 600 !important;
}

.empty-table-state p {
  font-size: 0.95rem !important;
  opacity: 0.8 !important;
  max-width: 400px !important;
  margin: 0 auto !important;
}

/* Modo escuro - estados vazios */
.dark-mode .empty-table-state {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.5) 0%, rgba(26, 32, 44, 0.5) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.dark-mode .empty-table-state h5 {
  color: #e2e8f0 !important;
}

/* =============================================
   ELEMENTOS VISUAIS ADICIONAIS PARA TABELAS
   ============================================= */

/* Indicadores visuais de prioridade nas linhas */
.priority-indicator {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  margin-right: 0.5rem !important;
  animation: pulse-indicator 2s infinite !important;
}

@keyframes pulse-indicator {
  0% { opacity: 0.7; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.2); }
  100% { opacity: 0.7; transform: scale(1); }
}

.priority-high {
  background: linear-gradient(135deg, #dc3545 0%, #c82333 100%) !important;
  box-shadow: 0 0 10px rgba(220, 53, 69, 0.5) !important;
}

.priority-medium {
  background: linear-gradient(135deg, #ffc107 0%, #e0a800 100%) !important;
  box-shadow: 0 0 10px rgba(255, 193, 7, 0.5) !important;
}

.priority-low {
  background: linear-gradient(135deg, #17a2b8 0%, #138496 100%) !important;
  box-shadow: 0 0 10px rgba(23, 162, 184, 0.5) !important;
}

/* Cards de informações das tabelas com glassmorphism avançado */
.table-info-card {
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.95) 0%, rgba(233, 236, 239, 0.95) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  border-radius: 15px !important;
  padding: 1.5rem !important;
  margin-top: 1.5rem !important;
  backdrop-filter: blur(20px) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1) !important;
  position: relative !important;
  overflow: hidden !important;
}

.table-info-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(102, 126, 234, 0.5), transparent) !important;
}

.table-info-card .info-header {
  display: flex !important;
  align-items: center !important;
  margin-bottom: 1rem !important;
  padding-bottom: 0.75rem !important;
  border-bottom: 1px solid rgba(102, 126, 234, 0.2) !important;
}

.table-info-card .info-header i {
  color: #667eea !important;
  margin-right: 0.75rem !important;
  font-size: 1.25rem !important;
  filter: drop-shadow(0 2px 4px rgba(102, 126, 234, 0.3)) !important;
}

.table-info-card .info-header h6 {
  margin: 0 !important;
  color: #495057 !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
}

/* Modo escuro - cards de informações */
.dark-mode .table-info-card {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.95) 0%, rgba(26, 32, 44, 0.95) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3) !important;
}

.dark-mode .table-info-card .info-header i {
  color: #63b3ed !important;
}

.dark-mode .table-info-card .info-header h6 {
  color: #e2e8f0 !important;
}

/* Sistema de badges aprimorado para informações */
.info-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.375rem !important;
  padding: 0.25rem 0.75rem !important;
  border-radius: 20px !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  margin: 0.25rem !important;
  transition: all 0.3s ease !important;
  backdrop-filter: blur(5px) !important;
}

.info-badge:hover {
  transform: translateY(-1px) scale(1.05) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.info-badge-primary {
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.2) 0%, rgba(118, 75, 162, 0.2) 100%) !important;
  color: #667eea !important;
  border: 1px solid rgba(102, 126, 234, 0.3) !important;
}

.info-badge-success {
  background: linear-gradient(135deg, rgba(40, 167, 69, 0.2) 0%, rgba(33, 136, 56, 0.2) 100%) !important;
  color: #28a745 !important;
  border: 1px solid rgba(40, 167, 69, 0.3) !important;
}

.info-badge-warning {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.2) 0%, rgba(224, 168, 0, 0.2) 100%) !important;
  color: #ffc107 !important;
  border: 1px solid rgba(255, 193, 7, 0.3) !important;
}

.info-badge-danger {
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.2) 0%, rgba(200, 35, 51, 0.2) 100%) !important;
  color: #dc3545 !important;
  border: 1px solid rgba(220, 53, 69, 0.3) !important;
}

/* Área de estatísticas das tabelas */
.table-stats {
  display: flex !important;
  justify-content: space-around !important;
  padding: 1rem 0 !important;
  border-top: 1px solid rgba(102, 126, 234, 0.2) !important;
  margin-top: 1rem !important;
}

.table-stat {
  text-align: center !important;
}

.table-stat-number {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: #667eea !important;
  display: block !important;
  margin-bottom: 0.25rem !important;
  font-family: 'Courier New', monospace !important;
}

.table-stat-label {
  font-size: 0.75rem !important;
  color: #6c757d !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  font-weight: 500 !important;
}

/* Sistema de badges aprimorado para o modo dark */
.dark-mode .info-badge {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.8) 0%, rgba(26, 32, 44, 0.8) 100%) !important;
  color: #e2e8f0 !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
  backdrop-filter: blur(10px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
}

.dark-mode .info-badge-primary {
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.3) 0%, rgba(118, 75, 162, 0.3) 100%) !important;
  color: #90cdf4 !important;
  border: 1px solid rgba(102, 126, 234, 0.4) !important;
}

.dark-mode .info-badge-success {
  background: linear-gradient(135deg, rgba(40, 167, 69, 0.3) 0%, rgba(33, 136, 56, 0.3) 100%) !important;
  color: #68d391 !important;
  border: 1px solid rgba(40, 167, 69, 0.4) !important;
}

.dark-mode .info-badge-warning {
  background: linear-gradient(135deg, rgba(255, 193, 7, 0.3) 0%, rgba(224, 168, 0, 0.3) 100%) !important;
  color: #f6e05e !important;
  border: 1px solid rgba(255, 193, 7, 0.4) !important;
}

.dark-mode .info-badge-danger {
  background: linear-gradient(135deg, rgba(220, 53, 69, 0.3) 0%, rgba(200, 35, 51, 0.3) 100%) !important;
  color: #fc8181 !important;
  border: 1px solid rgba(220, 53, 69, 0.4) !important;
}

/* Área de estatísticas com melhor contraste no modo dark */
.dark-mode .table-stats {
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.3) 0%, rgba(26, 32, 44, 0.3) 100%) !important;
  backdrop-filter: blur(10px) !important;
  border-radius: 12px !important;
  margin: 1rem 0 !important;
}

.dark-mode .table-stat-number {
  color: #90cdf4 !important;
  font-weight: 700 !important;
  text-shadow: 0 2px 4px rgba(144, 205, 244, 0.3) !important;
}

.dark-mode .table-stat-label {
  color: #a0aec0 !important;
  font-weight: 600 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
}

/* Cards de informações das tabelas com melhor contraste no modo dark */
.dark-mode .table-info-card {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.98) 0%, rgba(26, 32, 44, 0.98) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4) !important;
  backdrop-filter: blur(25px) !important;
}

.dark-mode .table-info-card .info-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.dark-mode .table-info-card .info-header i {
  color: #90cdf4 !important;
  filter: drop-shadow(0 2px 4px rgba(144, 205, 244, 0.4)) !important;
}

.dark-mode .table-info-card .info-header h6 {
  color: #f7fafc !important;
  font-weight: 700 !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4) !important;
}

/* Responsividade aprimorada */
@media (max-width: 768px) {
  .enhanced-expiration-table {
    font-size: 0.8rem !important;
  }

  .enhanced-expiration-table th,
  .enhanced-expiration-table td {
    padding: 0.75rem 0.5rem !important;
  }

  .expiration-date {
    font-size: 0.75rem !important;
    padding: 0.375rem 0.5rem !important;
  }

  .expiration-date .date-text {
    margin-left: 1.25rem !important;
  }

  .table-info-footer-enhanced {
    padding: 0.75rem 1rem !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
  }

  .legend-indicators {
    justify-content: center !important;
  }
}

/* Estados vazios das tabelas */
.empty-table-state {
  text-align: center !important;
  padding: 3rem 2rem !important;
  color: #6c757d !important;
}

.empty-table-state i {
  font-size: 3rem !important;
  margin-bottom: 1rem !important;
  opacity: 0.5 !important;
}

.empty-table-state h5 {
  color: #495057 !important;
  margin-bottom: 0.5rem !important;
}

.empty-table-state p {
  font-size: 0.9rem !important;
  opacity: 0.8 !important;
}

/* =============================================
   GRÁFICOS DE MONITORAMENTO - ESTILO DOWNDETECTOR
   ============================================= */

/* Cards de Status do Sistema */
.system-status-card,
.online-clients-card,
.metric-card {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  border-radius: 15px !important;
  overflow: hidden !important;
}

.system-status-card:hover,
.online-clients-card:hover,
.metric-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15) !important;
}

.system-status-card .card-body,
.online-clients-card .card-body {
  padding: 1.5rem !important;
}

/* Modo Dark - Cards de Monitoramento */
.dark-mode .system-status-card,
.dark-mode .online-clients-card,
.dark-mode .metric-card {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.95) 0%, rgba(26, 32, 44, 0.95) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.4) !important;
}

.dark-mode .system-status-card:hover,
.dark-mode .online-clients-card:hover,
.dark-mode .metric-card:hover {
  border-color: rgba(144, 205, 244, 0.3) !important;
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.6) !important;
}

/* Títulos dos Cards de Monitoramento */
.system-status-card h5,
.online-clients-card h5 {
  font-weight: 700 !important;
  font-size: 1.1rem !important;
  color: #495057 !important;
}

.dark-mode .system-status-card h5,
.dark-mode .online-clients-card h5 {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
}

/* Valores Grandes (Uptime, Online Count) */
.uptime-percentage,
.online-count {
  font-weight: 800 !important;
  font-size: 2rem !important;
  line-height: 1 !important;
}

.dark-mode .uptime-percentage {
  color: #68d391 !important;
  text-shadow: 0 3px 6px rgba(104, 211, 145, 0.4) !important;
}

.dark-mode .online-count {
  color: #90cdf4 !important;
  text-shadow: 0 3px 6px rgba(144, 205, 244, 0.4) !important;
}

/* Containers dos Gráficos */
.uptime-chart-container,
.online-chart-container {
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.5) 0%, rgba(233, 236, 239, 0.5) 100%) !important;
  border-radius: 10px !important;
  padding: 10px !important;
  margin: 1rem 0 !important;
}

.dark-mode .uptime-chart-container,
.dark-mode .online-chart-container {
  background: linear-gradient(135deg, rgba(16, 22, 34, 0.6) 0%, rgba(35, 45, 62, 0.6) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.05) !important;
}

/* Badges de Status */
.system-status-card .badge,
.online-clients-card .badge {
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  padding: 0.5rem 1rem !important;
  border-radius: 20px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

.dark-mode .system-status-card .badge-success {
  background: linear-gradient(135deg, #68d391 0%, #48bb78 100%) !important;
  color: #1a202c !important;
  box-shadow: 0 4px 12px rgba(104, 211, 145, 0.3) !important;
}

.dark-mode .online-clients-card .badge-primary {
  background: linear-gradient(135deg, #90cdf4 0%, #63b3ed 100%) !important;
  color: #1a202c !important;
  box-shadow: 0 4px 12px rgba(144, 205, 244, 0.3) !important;
}

/* Texto Pequeno (Última verificação, etc) */
.system-status-card small,
.online-clients-card small {
  font-size: 0.8rem !important;
  opacity: 0.8 !important;
}

.dark-mode .system-status-card small,
.dark-mode .online-clients-card small {
  color: #cbd5e0 !important;
}

/* Cards de Métricas */
.metric-card {
  padding: 0.5rem !important;
}

.metric-card .card-body {
  padding: 1.25rem !important;
}

.metric-card h6 {
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  color: #6c757d !important;
  margin-bottom: 0.75rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

.dark-mode .metric-card h6 {
  color: #e2e8f0 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4) !important;
}

.metric-card h4 {
  font-weight: 800 !important;
  font-size: 1.75rem !important;
  margin-bottom: 0.25rem !important;
}

.dark-mode .metric-card h4 {
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
}

.dark-mode .metric-card .text-info {
  color: #90cdf4 !important;
}

.dark-mode .metric-card .text-warning {
  color: #fbd38d !important;
}

.dark-mode .metric-card .text-danger {
  color: #fc8181 !important;
}

.dark-mode .metric-card .text-success {
  color: #68d391 !important;
}

/* Ícones das Métricas */
.metric-card i {
  opacity: 0.9 !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2)) !important;
}

.dark-mode .metric-card i {
  filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.6)) !important;
}

/* Animação de Loading */
.online-count .fa-spinner {
  animation: spin 1s linear infinite !important;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Responsividade dos Gráficos */
@media (max-width: 768px) {
  .uptime-percentage,
  .online-count {
    font-size: 1.5rem !important;
  }

  .system-status-card h5,
  .online-clients-card h5 {
    font-size: 1rem !important;
  }

  .metric-card h4 {
    font-size: 1.5rem !important;
  }

  .uptime-chart-container,
  .online-chart-container {
    height: 50px !important;
  }
}

/* =============================================
   CARDS DE STATUS DOS SERVIDORES
   ============================================= */

.server-status-card {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  border-radius: 15px !important;
  overflow: hidden !important;
}

.server-status-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15) !important;
}

.server-status-card .card-body {
  padding: 1.25rem !important;
}

.server-status-card h6 {
  font-weight: 700 !important;
  font-size: 1rem !important;
  color: #495057 !important;
}

.server-status-card .server-url {
  font-size: 0.75rem !important;
  opacity: 0.8 !important;
  display: block !important;
  margin-top: 0.25rem !important;
}

/* Modo Dark - Cards de Servidores */
.dark-mode .server-status-card {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.95) 0%, rgba(26, 32, 44, 0.95) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.4) !important;
}

.dark-mode .server-status-card:hover {
  border-color: rgba(144, 205, 244, 0.3) !important;
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.6) !important;
}

.dark-mode .server-status-card h6 {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
}

.dark-mode .server-status-card .server-url {
  color: #cbd5e0 !important;
}

/* Container do Gráfico de Servidor */
.server-chart-container {
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.5) 0%, rgba(233, 236, 239, 0.5) 100%) !important;
  border-radius: 8px !important;
  padding: 8px !important;
  margin: 0.75rem 0 !important;
}

.dark-mode .server-chart-container {
  background: linear-gradient(135deg, rgba(16, 22, 34, 0.6) 0%, rgba(35, 45, 62, 0.6) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.05) !important;
}

/* Badges de Status dos Servidores */
.server-status-card .server-badge {
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  padding: 0.35rem 0.75rem !important;
  border-radius: 15px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  transition: all 0.3s ease !important;
}

.dark-mode .server-status-card .badge-success {
  background: linear-gradient(135deg, #68d391 0%, #48bb78 100%) !important;
  color: #1a202c !important;
  box-shadow: 0 4px 12px rgba(104, 211, 145, 0.3) !important;
}

.dark-mode .server-status-card .badge-danger {
  background: linear-gradient(135deg, #fc8181 0%, #f56565 100%) !important;
  color: #1a202c !important;
  box-shadow: 0 4px 12px rgba(252, 129, 129, 0.3) !important;
}

.dark-mode .server-status-card .badge-secondary {
  background: linear-gradient(135deg, #a0aec0 0%, #718096 100%) !important;
  color: #1a202c !important;
}

/* Texto Pequeno dos Servidores */
.server-status-card small {
  font-size: 0.75rem !important;
  opacity: 0.8 !important;
}

.dark-mode .server-status-card small {
  color: #cbd5e0 !important;
}

.dark-mode .server-status-card .server-response-time,
.dark-mode .server-status-card .server-uptime {
  color: #e2e8f0 !important;
  font-weight: 600 !important;
}

/* Título da Seção de Servidores */
.dark-mode h5 {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
}

/* Animação de Pulso para Badges */
.server-badge .fa-spinner {
  animation: spin 1s linear infinite !important;
}

/* Responsividade dos Cards de Servidores */
@media (max-width: 768px) {
  .server-status-card h6 {
    font-size: 0.9rem !important;
  }

  .server-status-card .server-url {
    font-size: 0.7rem !important;
  }

  .server-chart-container {
    height: 35px !important;
  }
}

/* =============================================
   PÁGINA DE GERIR CLIENTES - DESIGN MODERNO
   ============================================= */

/* Header da Página */
.page-header-modern {
  padding: 1.5rem 0 !important;
  margin-bottom: 2rem !important;
}

.page-title {
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  color: #2d3748 !important;
  margin-bottom: 0.5rem !important;
  display: flex !important;
  align-items: center !important;
}

.dark-mode .page-title {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
}

.page-subtitle {
  font-size: 0.95rem !important;
  color: #718096 !important;
  font-weight: 400 !important;
}

.dark-mode .page-subtitle {
  color: #cbd5e0 !important;
}

/* Botão Moderno */
.btn-modern {
  padding: 0.625rem 1.5rem !important;
  font-weight: 600 !important;
  border-radius: 10px !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

.btn-modern:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15) !important;
}

.dark-mode .btn-modern {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4) !important;
}

.dark-mode .btn-modern:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.6) !important;
}

/* Card Moderno */
.card-modern {
  border-radius: 15px !important;
  border: none !important;
  overflow: hidden !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.dark-mode .card-modern {
  background: linear-gradient(135deg, rgba(45, 55, 72, 0.95) 0%, rgba(26, 32, 44, 0.95) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Header do Card */
.card-header-modern {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  color: #ffffff !important;
  padding: 1.25rem 1.5rem !important;
  border-bottom: none !important;
}

.dark-mode .card-header-modern {
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.9) 0%, rgba(118, 75, 162, 0.9) 100%) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.card-header-modern .card-title {
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 1.1rem !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
}

/* Filtros Modernos */
.filters-modern {
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.8) 0%, rgba(233, 236, 239, 0.8) 100%) !important;
  border-radius: 12px !important;
  padding: 1.5rem !important;
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.dark-mode .filters-modern {
  background: linear-gradient(135deg, rgba(26, 32, 44, 0.6) 0%, rgba(45, 55, 72, 0.6) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.form-group-modern {
  margin-bottom: 0 !important;
}

.form-label-modern {
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  color: #4a5568 !important;
  margin-bottom: 0.5rem !important;
  display: block !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

.dark-mode .form-label-modern {
  color: #e2e8f0 !important;
}

.form-control-modern {
  border-radius: 8px !important;
  border: 1px solid #e2e8f0 !important;
  padding: 0.625rem 1rem !important;
  font-size: 0.9rem !important;
  transition: all 0.3s ease !important;
  background-color: #ffffff !important;
}

.form-control-modern:focus {
  border-color: #667eea !important;
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1) !important;
}

.dark-mode .form-control-modern {
  background-color: rgba(26, 32, 44, 0.8) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
  color: #e2e8f0 !important;
}

.dark-mode .form-control-modern:focus {
  border-color: #667eea !important;
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.2) !important;
}

/* Container da Tabela */
.table-container-modern {
  border-radius: 10px !important;
  overflow: hidden !important;
}

/* Tabela Moderna */
.table-modern {
  margin-bottom: 0 !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

.table-modern thead th {
  background: linear-gradient(135deg, #f7fafc 0%, #edf2f7 100%) !important;
  color: #2d3748 !important;
  font-weight: 700 !important;
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  padding: 1rem 0.75rem !important;
  border-bottom: 2px solid #e2e8f0 !important;
  white-space: nowrap !important;
}

.dark-mode .table-modern thead th {
  background: linear-gradient(135deg, rgba(26, 32, 44, 0.8) 0%, rgba(45, 55, 72, 0.8) 100%) !important;
  color: #e2e8f0 !important;
  border-bottom: 3px solid rgba(255, 255, 255, 0.2) !important;
}

.table-modern tbody tr {
  transition: all 0.2s ease !important;
  border-bottom: 1px solid #f1f5f9 !important;
}

.table-modern tbody tr:hover {
  background-color: rgba(102, 126, 234, 0.05) !important;
  transform: scale(1.01) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05) !important;
}

.dark-mode .table-modern tbody tr {
  border-bottom: 2px solid rgba(255, 255, 255, 0.15) !important;
}

.dark-mode .table-modern tbody tr:hover {
  background-color: rgba(102, 126, 234, 0.1) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
  border-bottom: 2px solid rgba(102, 126, 234, 0.3) !important;
}

.table-modern tbody td {
  padding: 0.875rem 0.75rem !important;
  vertical-align: middle !important;
  font-size: 0.9rem !important;
}

.dark-mode .table-modern tbody td {
  color: #e2e8f0 !important;
  border-left: 1px solid rgba(255, 255, 255, 0.05) !important;
}

.dark-mode .table-modern tbody td:first-child {
  border-left: none !important;
}

/* Rodapé da Tabela */
.table-footer-modern {
  background: linear-gradient(135deg, rgba(248, 249, 250, 0.8) 0%, rgba(233, 236, 239, 0.8) 100%) !important;
  border-radius: 10px !important;
  padding: 1rem 1.5rem !important;
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.dark-mode .table-footer-modern {
  background: linear-gradient(135deg, rgba(26, 32, 44, 0.6) 0%, rgba(45, 55, 72, 0.6) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.legend-indicators .badge {
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  padding: 0.4rem 0.75rem !important;
  border-radius: 8px !important;
}

/* Botões de Ação na Tabela */
.table-modern .btn-sm {
  padding: 0.375rem 0.75rem !important;
  font-size: 0.8rem !important;
  border-radius: 6px !important;
  transition: all 0.2s ease !important;
}

.table-modern .btn-sm:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15) !important;
}

/* Dropdown Menu Moderno */
.dropdown-menu {
  border-radius: 10px !important;
  border: none !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15) !important;
  padding: 0.5rem !important;
}

.dark-mode .dropdown-menu {
  background-color: rgba(26, 32, 44, 0.95) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.6) !important;
}

.dropdown-item {
  border-radius: 6px !important;
  padding: 0.625rem 1rem !important;
  transition: all 0.2s ease !important;
  font-size: 0.9rem !important;
}

.dropdown-item:hover {
  background-color: rgba(102, 126, 234, 0.1) !important;
  transform: translateX(5px) !important;
}

.dark-mode .dropdown-item {
  color: #e2e8f0 !important;
}

.dark-mode .dropdown-item:hover {
  background-color: rgba(102, 126, 234, 0.2) !important;
}

/* DataTables Customização */
.dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: 6px !important;
  padding: 0.375rem 0.75rem !important;
  margin: 0 2px !important;
  transition: all 0.2s ease !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
}

.dark-mode .dataTables_wrapper .dataTables_info,
.dark-mode .dataTables_wrapper .dataTables_length label,
.dark-mode .dataTables_wrapper .dataTables_filter label {
  color: #e2e8f0 !important;
}

/* Select2 Customização */
.select2-container--default .select2-selection--single {
  border-radius: 8px !important;
  border: 1px solid #e2e8f0 !important;
  height: auto !important;
  padding: 0.375rem !important;
}

.dark-mode .select2-container--default .select2-selection--single {
  background-color: rgba(26, 32, 44, 0.8) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
  color: #e2e8f0 !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #2d3748 !important;
  padding-left: 0.5rem !important;
}

.dark-mode .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #e2e8f0 !important;
}

/* Responsividade */
@media (max-width: 992px) {
  .page-header-modern {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .header-actions {
    margin-top: 1rem !important;
    width: 100% !important;
  }

  .btn-modern {
    width: 100% !important;
  }

  .page-title {
    font-size: 1.5rem !important;
  }
}

@media (max-width: 768px) {
  .filters-modern {
    padding: 1rem !important;
  }

  .form-label-modern {
    font-size: 0.8rem !important;
  }

  .table-modern thead th {
    font-size: 0.75rem !important;
    padding: 0.75rem 0.5rem !important;
  }

  .table-modern tbody td {
    font-size: 0.8rem !important;
    padding: 0.625rem 0.5rem !important;
  }

  .legend-indicators {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .legend-indicators .badge {
    margin-bottom: 0.25rem !important;
  }
}

/* =============================================
   PÁGINA DE CRIAR CLIENTE - DESIGN MODERNO
   ============================================= */

/* Seções do Formulário */
.form-section-header {
  border-bottom: 2px solid #e2e8f0 !important;
  padding-bottom: 0.75rem !important;
  margin-bottom: 1.5rem !important;
}

.dark-mode .form-section-header {
  border-bottom: 2px solid rgba(255, 255, 255, 0.15) !important;
}

.form-section-title {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: #667eea !important;
  margin-bottom: 0 !important;
  display: flex !important;
  align-items: center !important;
}

.dark-mode .form-section-title {
  color: #90cdf4 !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.4) !important;
}

/* Input Groups Modernos */
.input-group-text {
  background: linear-gradient(135deg, #f7fafc 0%, #edf2f7 100%) !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 8px 0 0 8px !important;
  color: #4a5568 !important;
}

.dark-mode .input-group-text {
  background: linear-gradient(135deg, rgba(26, 32, 44, 0.8) 0%, rgba(45, 55, 72, 0.8) 100%) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
  color: #e2e8f0 !important;
}

.input-group .form-control-modern {
  border-radius: 0 !important;
}

.input-group .form-control-modern:focus {
  z-index: 3 !important;
}

.input-group-append .btn {
  border-radius: 0 8px 8px 0 !important;
  border-left: none !important;
}

/* Botão de Gerar */
.btn-outline-info.generate {
  transition: all 0.3s ease !important;
}

.btn-outline-info.generate:hover {
  transform: rotate(180deg) !important;
  background-color: #17a2b8 !important;
  color: #ffffff !important;
}

/* Custom Switch Moderno */
.custom-switch .custom-control-label::before {
  border-radius: 1rem !important;
  background-color: #cbd5e0 !important;
  border: none !important;
}

.dark-mode .custom-switch .custom-control-label::before {
  background-color: rgba(255, 255, 255, 0.2) !important;
}

.custom-switch .custom-control-input:checked~.custom-control-label::before {
  background-color: #667eea !important;
  border-color: #667eea !important;
}

/* Alert Info Moderno */
.alert-info {
  background: linear-gradient(135deg, rgba(23, 162, 184, 0.1) 0%, rgba(23, 162, 184, 0.05) 100%) !important;
  border: 1px solid rgba(23, 162, 184, 0.2) !important;
  color: #0c5460 !important;
}

.dark-mode .alert-info {
  background: linear-gradient(135deg, rgba(23, 162, 184, 0.2) 0%, rgba(23, 162, 184, 0.1) 100%) !important;
  border: 1px solid rgba(23, 162, 184, 0.3) !important;
  color: #90cdf4 !important;
}

.alert-info .alert-heading {
  color: #17a2b8 !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
}

.dark-mode .alert-info .alert-heading {
  color: #90cdf4 !important;
}

.alert-info ul {
  padding-left: 1.5rem !important;
}

.alert-info ul li {
  margin-bottom: 0.5rem !important;
}

/* Card Footer Moderno */
.dark-mode .card-footer {
  background: linear-gradient(135deg, rgba(26, 32, 44, 0.6) 0%, rgba(45, 55, 72, 0.6) 100%) !important;
  border-top: 2px solid rgba(255, 255, 255, 0.1) !important;
}

/* Textarea Moderno */
textarea.form-control-modern {
  resize: vertical !important;
  min-height: 80px !important;
}

/* Responsividade para Criar Cliente */
@media (max-width: 992px) {
  .form-section-header {
    margin-top: 2rem !important;
  }

  .form-section-header:first-child {
    margin-top: 0 !important;
  }
}
