/* Dashboard Theme — GEARVN Đối soát NXT */
:root {
  --primary: #2563eb;
  --primary-light: #dbeafe;
  --success: #16a34a;
  --success-light: #dcfce7;
  --warning: #d97706;
  --warning-light: #fef3c7;
  --danger: #dc2626;
  --danger-light: #fee2e2;
  --info: #0891b2;
  --info-light: #cffafe;
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-500: #6b7280;
  --gray-700: #374151;
  --gray-900: #111827;
  --sidebar-bg: #1e293b;
  --sidebar-text: #e2e8f0;
  --sidebar-active: #3b82f6;
  --card-shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);
  --radius: 8px;
}
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; background: var(--gray-50); color: var(--gray-900); line-height: 1.5; }
a { color: var(--primary); text-decoration: none; }

/* Layout */
.layout { display: flex; min-height: 100vh; }
.sidebar { width: 240px; background: var(--sidebar-bg); color: var(--sidebar-text); padding: 20px 0; position: fixed; top: 0; bottom: 0; overflow-y: auto; z-index: 10; }
.sidebar-brand { padding: 0 20px 20px; border-bottom: 1px solid rgba(255,255,255,.1); margin-bottom: 12px; }
.sidebar-brand h2 { font-size: 16px; font-weight: 700; color: #fff; }
.sidebar-brand .subtitle { font-size: 11px; color: var(--gray-300); margin-top: 2px; }
.nav-list { list-style: none; }
.nav-item a { display: flex; align-items: center; padding: 10px 20px; color: var(--sidebar-text); font-size: 14px; transition: background .15s; }
.nav-item a:hover { background: rgba(255,255,255,.08); }
.nav-item.active a { background: var(--sidebar-active); color: #fff; font-weight: 600; }
.nav-icon { width: 20px; margin-right: 10px; text-align: center; }
.main { margin-left: 240px; flex: 1; padding: 24px 32px; max-width: 1200px; }

/* Header */
.page-header { margin-bottom: 24px; }
.page-header h1 { font-size: 24px; font-weight: 700; color: var(--gray-900); }
.page-header .desc { color: var(--gray-500); font-size: 14px; margin-top: 4px; }

/* Stats Grid */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 24px; }
.stat-card { background: #fff; border-radius: var(--radius); padding: 20px; box-shadow: var(--card-shadow); border-left: 4px solid var(--primary); }
.stat-card.success { border-left-color: var(--success); }
.stat-card.warning { border-left-color: var(--warning); }
.stat-card.danger { border-left-color: var(--danger); }
.stat-card.info { border-left-color: var(--info); }
.stat-label { font-size: 12px; text-transform: uppercase; color: var(--gray-500); font-weight: 600; letter-spacing: .5px; }
.stat-value { font-size: 28px; font-weight: 700; margin-top: 4px; }
.stat-sub { font-size: 12px; color: var(--gray-500); margin-top: 2px; }

/* Cards */
.card { background: #fff; border-radius: var(--radius); box-shadow: var(--card-shadow); margin-bottom: 20px; }
.card-header { padding: 16px 20px; border-bottom: 1px solid var(--gray-200); font-weight: 600; font-size: 15px; display: flex; align-items: center; justify-content: space-between; }
.card-body { padding: 20px; }

/* Tables */
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th { text-align: left; padding: 10px 12px; background: var(--gray-50); border-bottom: 2px solid var(--gray-200); font-weight: 600; color: var(--gray-700); font-size: 12px; text-transform: uppercase; letter-spacing: .3px; }
td { padding: 10px 12px; border-bottom: 1px solid var(--gray-100); }
tr:hover { background: var(--gray-50); }

/* Badges */
.badge { display: inline-block; padding: 2px 8px; border-radius: 12px; font-size: 11px; font-weight: 600; }
.badge-done { background: var(--success-light); color: var(--success); }
.badge-progress { background: var(--primary-light); color: var(--primary); }
.badge-cancel { background: var(--gray-100); color: var(--gray-500); }
.badge-critical { background: var(--danger-light); color: var(--danger); }
.badge-high { background: var(--warning-light); color: var(--warning); }
.badge-medium { background: var(--info-light); color: var(--info); }
.badge-confirmed { background: var(--success-light); color: var(--success); }
.badge-pending { background: var(--warning-light); color: var(--warning); }

/* Progress bar */
.progress-bar { background: var(--gray-200); border-radius: 4px; height: 8px; overflow: hidden; }
.progress-fill { background: var(--success); height: 100%; border-radius: 4px; transition: width .3s; }

/* Timeline */
.timeline { position: relative; padding-left: 28px; }
.timeline::before { content:''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: var(--gray-200); }
.timeline-item { position: relative; margin-bottom: 20px; }
.timeline-dot { position: absolute; left: -24px; top: 4px; width: 12px; height: 12px; border-radius: 50%; border: 2px solid var(--primary); background: #fff; }
.timeline-dot.done { background: var(--success); border-color: var(--success); }
.timeline-dot.active { background: var(--primary); border-color: var(--primary); }
.timeline-dot.future { background: var(--gray-200); border-color: var(--gray-300); }
.timeline-date { font-size: 12px; color: var(--gray-500); font-weight: 600; }
.timeline-title { font-size: 14px; font-weight: 600; margin-top: 2px; }
.timeline-desc { font-size: 13px; color: var(--gray-500); margin-top: 2px; }

/* Risk matrix */
.risk-item { padding: 16px; border-left: 4px solid var(--gray-300); margin-bottom: 12px; background: var(--gray-50); border-radius: 0 var(--radius) var(--radius) 0; }
.risk-item.critical { border-left-color: var(--danger); background: var(--danger-light); }
.risk-item.high { border-left-color: var(--warning); background: var(--warning-light); }
.risk-item.medium { border-left-color: var(--info); background: var(--info-light); }
.risk-title { font-weight: 600; font-size: 14px; margin-bottom: 4px; }
.risk-detail { font-size: 13px; color: var(--gray-700); }

/* Footer */
.footer { margin-top: 40px; padding: 16px 0; border-top: 1px solid var(--gray-200); font-size: 12px; color: var(--gray-500); text-align: center; }

/* Responsive */
@media (max-width: 768px) {
  .sidebar { display: none; }
  .main { margin-left: 0; padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
