/**
 * Zahya Store - Dashboard Theme Integration
 * This file provides theme variables and switching functionality
 * for the dashboard interface
 */

:root {
  /* Base colors that don't change with theme */
  --primary: #6366f1;
  --primary-dark: #4f46e5;
  --primary-light: #818cf8;
  --primary-bg: rgba(99, 102, 241, 0.1);
  --success: #10b981;
  --warning: #f59e0b;
  --danger: #ef4444;
  --info: #0ea5e9;
}

/* Dark Theme (Default) */
body.theme-dark {
  /* Background colors */
  --body-bg: #151823;
  --card-bg: #1e2130;
  --card-bg-hover: #252a3d;
  --sidebar-bg: #1e2130;
  --navbar-bg: #1e2130;
  --input-bg: #252a3d;
  --dropdown-bg: #1e2130;
  --dropdown-item-hover: #252a3d;
  
  /* Text colors */
  --text-primary: #e2e8f0;
  --text-secondary: #94a3b8;
  --text-muted: #64748b;
  
  /* Border colors */
  --border-color: #2a2f42;
  --divider-color: #2a2f42;
  
  /* Status colors with opacity */
  --success-bg: rgba(16, 185, 129, 0.15);
  --success-border: rgba(16, 185, 129, 0.3);
  --success-text: #34d399;
  
  --warning-bg: rgba(245, 158, 11, 0.15);
  --warning-border: rgba(245, 158, 11, 0.3);
  --warning-text: #fbbf24;
  
  --danger-bg: rgba(239, 68, 68, 0.15);
  --danger-border: rgba(239, 68, 68, 0.3);
  --danger-text: #f87171;
  
  --info-bg: rgba(14, 165, 233, 0.15);
  --info-border: rgba(14, 165, 233, 0.3);
  --info-text: #38bdf8;
  
  --neutral-bg: rgba(107, 114, 128, 0.15);
  --neutral-border: rgba(107, 114, 128, 0.3);
  --neutral-text: #9ca3af;
  
  /* Shadow colors */
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.5);
  
  /* Chart colors */
  --chart-line: rgba(255, 255, 255, 0.1);
  --chart-text: rgba(255, 255, 255, 0.7);
}

/* Light Theme */
body.theme-light {
  /* Background colors */
  --body-bg: #f8fafc;
  --card-bg: #ffffff;
  --card-bg-hover: #f1f5f9;
  --sidebar-bg: #ffffff;
  --navbar-bg: #ffffff;
  --input-bg: #f1f5f9;
  --dropdown-bg: #ffffff;
  --dropdown-item-hover: #f1f5f9;
  
  /* Text colors */
  --text-primary: #1e293b;
  --text-secondary: #475569;
  --text-muted: #64748b;
  
  /* Border colors */
  --border-color: #e2e8f0;
  --divider-color: #e2e8f0;
  
  /* Status colors with opacity */
  --success-bg: rgba(16, 185, 129, 0.1);
  --success-border: rgba(16, 185, 129, 0.2);
  --success-text: #10b981;
  
  --warning-bg: rgba(245, 158, 11, 0.1);
  --warning-border: rgba(245, 158, 11, 0.2);
  --warning-text: #f59e0b;
  
  --danger-bg: rgba(239, 68, 68, 0.1);
  --danger-border: rgba(239, 68, 68, 0.2);
  --danger-text: #ef4444;
  
  --info-bg: rgba(14, 165, 233, 0.1);
  --info-border: rgba(14, 165, 233, 0.2);
  --info-text: #0ea5e9;
  
  --neutral-bg: rgba(107, 114, 128, 0.1);
  --neutral-border: rgba(107, 114, 128, 0.2);
  --neutral-text: #6b7280;
  
  /* Shadow colors */
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
  
  /* Chart colors */
  --chart-line: rgba(0, 0, 0, 0.1);
  --chart-text: rgba(0, 0, 0, 0.7);
}

/* Apply theme styles to elements */

/* Base elements */
body {
  background-color: var(--body-bg);
  color: var(--text-primary);
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Dashboard section */
.dashboard-section {
  background-color: var(--body-bg);
}

/* Navbar */
.dashboard-navbar {
  background-color: var(--navbar-bg);
  border-bottom: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}

.search-input {
  background-color: var(--input-bg);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
}

.search-input:focus {
  border-color: var(--primary);
}

.search-input::placeholder {
  color: var(--text-muted);
}

.search-icon {
  color: var(--text-muted);
}

.navbar-action-btn {
  background-color: var(--input-bg);
  border: 1px solid var(--border-color);
  color: var(--text-secondary);
}

.navbar-action-btn:hover {
  background-color: var(--card-bg-hover);
  color: var(--text-primary);
}

.navbar-divider {
  background-color: var(--divider-color);
}

.user-dropdown-toggle {
  color: var(--text-primary);
}

.user-dropdown-toggle:hover {
  background-color: var(--card-bg-hover);
}

.dropdown-arrow {
  color: var(--text-muted);
}

.user-dropdown-menu {
  background-color: var(--dropdown-bg);
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-md);
}

.dropdown-user-header {
  border-bottom: 1px solid var(--border-color);
  background-color: var(--card-bg-hover);
}

.dropdown-user-name {
  color: var(--text-primary);
}

.dropdown-user-role {
  color: var(--text-muted);
}

.dropdown-item {
  color: var(--text-primary);
}

.dropdown-item:hover {
  background-color: var(--dropdown-item-hover);
}

.dropdown-item-icon {
  color: var(--text-secondary);
}

.dropdown-item:hover .dropdown-item-icon {
  color: var(--primary);
}

.dropdown-divider {
  background-color: var(--divider-color);
}

/* Sidebar */
.dashboard-sidebar {
  background-color: var(--sidebar-bg);
  border-right: 1px solid var(--border-color);
}

.nav-section-title {
  color: var(--text-muted);
}

.sidebar-nav .nav-link {
  color: var(--text-secondary);
}

.sidebar-nav .nav-link:hover,
.sidebar-nav .nav-link.active {
  background-color: var(--card-bg-hover);
  color: var(--text-primary);
}

.sidebar-nav .nav-link.active {
  border-left: 3px solid var(--primary);
}

.sidebar-nav .nav-icon {
  color: var(--text-secondary);
}

.sidebar-nav .nav-link:hover .nav-icon,
.sidebar-nav .nav-link.active .nav-icon {
  color: var(--primary);
}

.sidebar-footer {
  border-top: 1px solid var(--border-color);
}

.btn-theme-logout {
  background-color: var(--input-bg);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
}

.btn-theme-logout:hover {
  background-color: var(--primary);
  border-color: var(--primary);
  color: white;
}

/* Dashboard Header */
.dashboard-header {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}

.dashboard-title {
  color: var(--text-primary);
}

/* Welcome Card */
.welcome-card {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  padding: 25px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-image: linear-gradient(45deg, var(--primary-bg), transparent);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.welcome-title {
  color: var(--text-primary);
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 10px;
}

.welcome-text {
  color: var(--text-secondary);
  font-size: 14px;
  max-width: 500px;
}

.welcome-card-illustration {
  font-size: 60px;
  color: var(--primary);
  opacity: 0.8;
}

/* Cards */
.activity-card {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}

.activity-card:hover {
  box-shadow: var(--shadow-md);
}

.activity-card-header {
  border-bottom: 1px solid var(--border-color);
  background: linear-gradient(to right, var(--card-bg-hover), var(--card-bg));
}

.activity-card-title {
  color: var(--text-primary);
}

.activity-card-icon {
  color: var(--primary);
}

.view-all-link {
  color: var(--primary);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
}

.view-all-link:hover {
  text-decoration: underline;
}

.activity-item {
  border-bottom: 1px solid var(--border-color);
}

.activity-item:hover {
  background-color: var(--card-bg-hover);
}

.activity-item-img {
  background-color: var(--input-bg);
  border: 1px solid var(--border-color);
}

.activity-item-img-placeholder,
.ticket-img {
  color: var(--primary);
}

.activity-item-title {
  color: var(--text-primary);
}

.activity-item-details {
  color: var(--text-secondary);
}

.activity-item-action {
  background-color: var(--input-bg);
  color: var(--text-secondary);
  border: 1px solid var(--border-color);
}

.activity-item:hover .activity-item-action {
  background-color: var(--primary);
  color: white;
}

.activity-empty-icon {
  background-color: var(--input-bg);
  color: var(--text-muted);
}

.activity-empty-text {
  color: var(--text-secondary);
}

/* Stats Cards */
.stats-card {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}

.stats-card:hover {
  box-shadow: var(--shadow-md);
}

.stats-title {
  color: var(--text-secondary);
}

.stats-number {
  color: var(--text-primary);
}

.stats-card:hover .stats-number {
  color: var(--primary);
}

.stats-card-link {
  display: block;
  padding: 12px 20px;
  text-align: right;
  color: var(--primary);
  font-size: 13px;
  font-weight: 500;
  border-top: 1px solid var(--border-color);
  text-decoration: none;
  transition: all 0.2s ease;
}

.stats-card-link:hover {
  background-color: var(--primary-bg);
  color: var(--primary-dark);
}

/* Support Card */
.support-card {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  padding: 20px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: all 0.3s ease;
}

.support-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
}

.support-card-icon {
  width: 60px;
  height: 60px;
  margin: 0 auto 15px;
  border-radius: 50%;
  background-color: var(--primary-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: var(--primary);
}

.support-card-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 10px;
}

.support-card-text {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 15px;
}

/* Chart container */
.chart-container {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}

.chart-container:hover {
  box-shadow: var(--shadow-md);
}

.chart-title {
  color: var(--text-primary);
}

.legend-item {
  color: var(--text-secondary);
}

/* Product cards */
.product-card {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: all 0.3s ease;
  height: 100%;
}

.product-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
}

.product-thumbnail {
  width: 100%;
  height: 140px;
  background-color: var(--input-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.product-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.product-placeholder {
  color: var(--text-muted);
  font-size: 30px;
}

.product-info {
  padding: 15px;
}

.product-title {
  color: var(--text-primary);
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.product-price {
  color: var(--primary);
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 10px;
}

/* Status badges */
.status-badge {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

.status-badge.status-completed,
.status-badge.status-paid {
  background-color: var(--success-bg);
  color: var(--success-text);
  border: 1px solid var(--success-border);
}

.status-badge.status-pending {
  background-color: var(--warning-bg);
  color: var(--warning-text);
  border: 1px solid var(--warning-border);
}

.status-badge.status-cancelled {
  background-color: var(--danger-bg);
  color: var(--danger-text);
  border: 1px solid var(--danger-border);
}

.status-badge.status-open {
  background-color: var(--info-bg);
  color: var(--info-text);
  border: 1px solid var(--info-border);
}

.status-badge.status-closed {
  background-color: var(--neutral-bg);
  color: var(--neutral-text);
  border: 1px solid var(--neutral-border);
}

.status-badge.status-in_progress,
.status-badge.status-processing {
  background-color: var(--info-bg);
  color: var(--info-text);
  border: 1px solid var(--info-border);
  animation: pulse 1.5s infinite ease-in-out;
}

/* Buttons */
.btn-primary {
  background-color: var(--primary);
  border-color: var(--primary);
}

.btn-primary:hover {
  background-color: var(--primary-dark);
  border-color: var(--primary-dark);
}

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

.btn-outline-primary:hover {
  background-color: var(--primary);
  border-color: var(--primary);
  color: white;
}

.btn-outline-secondary {
  color: var(--text-secondary);
  border-color: var(--border-color);
}

.btn-outline-secondary:hover {
  background-color: var(--card-bg-hover);
  color: var(--text-primary);
}

.btn-outline-secondary.active {
  background-color: var(--primary);
  color: white;
  border-color: var(--primary);
}

/* Ticket items */
.ticket-list {
  border-radius: 10px;
  overflow: hidden;
}

.list-group-item {
  background-color: var(--card-bg);
  border-color: var(--border-color);
  color: var(--text-primary);
}

.list-group-item:hover {
  background-color: var(--card-bg-hover);
}

.ticket-title {
  color: var(--text-primary);
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 5px;
}

.text-muted {
  color: var(--text-muted) !important;
}

/* Theme-driven scrollbar */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background-color: var(--divider-color);
  border-radius: 6px;
}

::-webkit-scrollbar-thumb:hover {
  background-color: var(--text-muted);
}

/* Animation for theme transition */
.theme-transition {
  transition: background-color 0.3s ease, 
              color 0.3s ease, 
              border-color 0.3s ease, 
              box-shadow 0.3s ease;
}

/* Theme Initialize Script */
document.addEventListener('DOMContentLoaded', function() {
  // Check for saved theme preference
  const savedTheme = localStorage.getItem('theme');
  
  // Apply saved theme or default to dark
  if (savedTheme === 'light') {
    document.body.classList.remove('theme-dark');
    document.body.classList.add('theme-light');
  } else {
    document.body.classList.remove('theme-light');
    document.body.classList.add('theme-dark');
  }
  
  // Add transition class after initial load to enable smooth transitions
  setTimeout(function() {
    document.body.classList.add('theme-transition');
  }, 100);
});
