/* =================================================================
   SC AccountingPro · Theme — Premium Accounting (น้ำเงินเข้ม + ทอง)
   ================================================================= */
:root {
  --primary: #2A4365;
  --primary-light: #2B6CB0;
  --primary-dark: #1A365D;
  --accent: #D69E2E;
  --accent-light: #F6E05E;
  --success: #38A169;
  --warning: #DD6B20;
  --danger: #C53030;
  --cream: #FFF8E7;
  --gray-50: #F7FAFC;
  --gray-100: #EDF2F7;
  --gray-200: #E2E8F0;
  --gray-300: #CBD5E0;
  --gray-500: #718096;
  --gray-700: #2D3748;
  --gray-900: #1A202C;
}

* {
  font-family: "Sarabun", "TH SarabunPSK", system-ui, -apple-system, sans-serif;
}

body {
  background: var(--gray-50);
  color: var(--gray-700);
}

/* Custom scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--gray-100); }
::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--gray-500); }

/* Status indicators */
.status-online::before {
  content: ""; display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; background: var(--success);
  margin-right: 6px; box-shadow: 0 0 0 2px rgba(56,161,105,0.2);
  animation: pulse-green 2s infinite;
}
.status-idle::before {
  content: ""; display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; background: var(--warning);
  margin-right: 6px;
}
.status-offline::before {
  content: ""; display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; background: var(--gray-300);
  margin-right: 6px;
}

@keyframes pulse-green {
  0%, 100% { box-shadow: 0 0 0 2px rgba(56,161,105,0.2); }
  50% { box-shadow: 0 0 0 6px rgba(56,161,105,0); }
}

/* Loading spinner */
.spinner {
  border: 3px solid var(--gray-200);
  border-top-color: var(--primary);
  border-radius: 50%;
  width: 24px; height: 24px;
  animation: spin 0.8s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Card hover effect */
.card-hover {
  transition: all 0.2s ease;
}
.card-hover:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}

/* Sidebar (Winspeed-style) */
.sidebar-item {
  display: flex; align-items: center;
  padding: 8px 12px; border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
  font-size: 14px;
  color: var(--gray-700);
}
.sidebar-item:hover {
  background: var(--gray-100);
}
.sidebar-item.active {
  background: var(--primary);
  color: white;
}
.sidebar-item .icon { width: 20px; margin-right: 8px; }

.sidebar-tree {
  padding-left: 24px;
  border-left: 1px dashed var(--gray-200);
  margin-left: 12px;
}

/* Badge */
.badge {
  display: inline-block;
  padding: 2px 8px; border-radius: 12px;
  font-size: 11px; font-weight: 600;
  background: var(--gray-200);
  color: var(--gray-700);
}
.badge-danger { background: #FED7D7; color: var(--danger); }
.badge-warning { background: #FEEBC8; color: var(--warning); }
.badge-success { background: #C6F6D5; color: var(--success); }
.badge-primary { background: #BEE3F8; color: var(--primary); }
