/**
 * Custom CSS - Sistema de Control de Cuotas Escolares
 * Colores: Primario #790495 (Púrpura) | Secundario #0452b5 (Azul)
 */

:root {
  --cole-primary: #790495;
  --cole-primary-hover: #5e0375;
  --cole-primary-light: #f3e5f5;
  --cole-primary-rgb: 121, 4, 149;
  --cole-secondary: #0452b5;
  --cole-secondary-hover: #033d8a;
  --cole-secondary-light: #e3f2fd;
  --cole-secondary-rgb: 4, 82, 181;
}

/* Override Sneat primary color */
.bg-primary, .btn-primary {
  background-color: var(--cole-primary) !important;
  border-color: var(--cole-primary) !important;
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--cole-primary-hover) !important;
  border-color: var(--cole-primary-hover) !important;
}
.btn-outline-primary {
  color: var(--cole-primary) !important;
  border-color: var(--cole-primary) !important;
}
.btn-outline-primary:hover {
  background-color: var(--cole-primary) !important;
  color: #fff !important;
}
.text-primary {
  color: var(--cole-primary) !important;
}
.bg-label-primary {
  background-color: var(--cole-primary-light) !important;
  color: var(--cole-primary) !important;
}

/* Secondary buttons */
.btn-secondary {
  background-color: var(--cole-secondary) !important;
  border-color: var(--cole-secondary) !important;
}
.btn-secondary:hover {
  background-color: var(--cole-secondary-hover) !important;
}

/* Sidebar menu */
.bg-menu-theme .menu-inner > .menu-item.active > .menu-link {
  background-color: var(--cole-primary) !important;
  color: #fff !important;
}
.bg-menu-theme .menu-inner > .menu-item.active > .menu-link .menu-icon {
  color: #fff !important;
}
.bg-menu-theme .menu-inner > .menu-item > .menu-link:hover {
  color: var(--cole-primary) !important;
}
.bg-menu-theme .menu-inner .menu-item .menu-link:hover .menu-icon {
  color: var(--cole-primary) !important;
}
.bg-menu-theme .menu-sub > .menu-item.active > .menu-link::before {
  background-color: var(--cole-primary) !important;
}

/* App brand logo */
.app-brand-logo img {
  max-height: 36px;
  width: auto;
}
.login-logo img {
  max-height: 80px;
  width: auto;
}

/* Cards styling */
.card {
  border: none;
  box-shadow: 0 2px 6px rgba(var(--cole-primary-rgb), 0.08);
  transition: transform 0.2s, box-shadow 0.2s;
}
.card:hover {
  box-shadow: 0 4px 15px rgba(var(--cole-primary-rgb), 0.12);
}

/* Stats cards */
.stats-card {
  border-left: 4px solid var(--cole-primary);
}
.stats-card.secondary {
  border-left-color: var(--cole-secondary);
}
.stats-card .stats-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
}
.stats-card .stats-icon.primary {
  background: var(--cole-primary-light);
  color: var(--cole-primary);
}
.stats-card .stats-icon.secondary {
  background: var(--cole-secondary-light);
  color: var(--cole-secondary);
}

/* Libreta de pagos */
.libreta-table th {
  background-color: var(--cole-primary);
  color: #fff;
  font-weight: 600;
  text-align: center;
  font-size: 0.85rem;
}
.libreta-table td {
  text-align: center;
  vertical-align: middle;
}
.libreta-table .pagado {
  background-color: #d4edda;
  color: #155724;
}
.libreta-table .pendiente {
  background-color: #fff3cd;
  color: #856404;
}
.libreta-table .vencido {
  background-color: #f8d7da;
  color: #721c24;
}

/* Badges */
.badge-pagado { background-color: #28a745; }
.badge-pendiente { background-color: #ffc107; color: #333; }
.badge-vencido { background-color: #dc3545; }

/* Login page */
.auth-page {
  min-height: 100vh;
  background: linear-gradient(135deg, var(--cole-primary) 0%, var(--cole-secondary) 100%);
}
.auth-card {
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}

/* Ticket print styles */
@media print {
  .layout-menu, .layout-navbar, .content-footer,
  .btn, .no-print, .buy-now { display: none !important; }
  .layout-page { margin-left: 0 !important; padding: 0 !important; }
  .content-wrapper { padding: 0 !important; }
  .ticket-container {
    width: 80mm;
    margin: 0;
    padding: 5mm;
    font-size: 12px;
  }
  .ticket-container h4 { font-size: 14px; }
  .ticket-container table { font-size: 11px; }
}

/* Search input */
.search-box {
  position: relative;
}
.search-box .search-results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 0 0 8px 8px;
  max-height: 250px;
  overflow-y: auto;
  z-index: 1050;
  display: none;
}
.search-box .search-results.show { display: block; }
.search-box .search-results .search-item {
  padding: 10px 15px;
  cursor: pointer;
  border-bottom: 1px solid #f0f0f0;
  transition: background 0.15s;
}
.search-box .search-results .search-item:hover {
  background-color: var(--cole-primary-light);
}

/* Fade in animation */
.fade-in {
  animation: fadeIn 0.3s ease-in;
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 768px) {
  .stats-card { margin-bottom: 1rem; }
  .table-responsive { font-size: 0.85rem; }
}
