/* Custom Theme Enhancements for Yayasan Al-Hasanah */

/* Scrollbar Customization */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--color-bg-secondary);
}

::-webkit-scrollbar-thumb {
  background: var(--color-neutral-light);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-neutral-gray);
}

/* Glassmorphism Styles */
.glass-panel {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.3);
}

/* Gradients */
.bg-gradient-primary {
  background: linear-gradient(135deg, var(--color-accent-teal) 0%, var(--color-accent-teal-dark) 100%);
  color: var(--color-white);
}

.bg-gradient-accent {
  background: linear-gradient(135deg, var(--color-primary-cyan) 0%, var(--color-primary-cyan-dark) 100%);
  color: var(--color-white);
}

/* Interactive elements */
.hover-lift {
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.hover-lift:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* Custom Profile Header Section */
.profile-menu {
  position: relative;
  display: inline-block;
}

.profile-trigger {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.profile-trigger:hover {
  background: var(--color-bg-tertiary);
}

.profile-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--color-primary-cyan-dark);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
  overflow: hidden;
  flex-shrink: 0;
}

.profile-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  width: 200px;
  background: var(--color-white);
  border: 1px solid var(--color-neutral-light);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  display: none;
  z-index: 100;
  margin-top: var(--spacing-xs);
  overflow: hidden;
}

.profile-dropdown.show {
  display: block;
}

.profile-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  font-size: var(--font-size-sm);
  color: var(--color-dark);
  transition: background var(--transition-fast);
}

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

button.profile-dropdown-item {
  font-family: inherit;
}

.profile-dropdown-divider {
  height: 1px;
  background: var(--color-neutral-light);
}

/* Dashboard Summary Cards Style */
.dash-card-cyan {
  border-left-color: var(--color-primary-cyan);
}
.dash-card-teal {
  border-left-color: var(--color-accent-teal);
}
.dash-card-success {
  border-left-color: var(--color-success);
}
.dash-card-danger {
  border-left-color: var(--color-danger);
}
.dash-card-warning {
  border-left-color: var(--color-warning);
}

/* Empty State Styling */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2xl) var(--spacing-md);
  text-align: center;
}

.empty-state-icon {
  font-size: var(--font-size-3xl);
  color: var(--color-neutral-gray);
  margin-bottom: var(--spacing-md);
}

.empty-state-title {
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-xs);
}

.empty-state-text {
  color: var(--color-neutral-gray);
  max-width: 400px;
}

/* =============================================================
   Theme Toggle & Dark Mode Support
   ============================================================= */

/* Theme Toggle Button */
.theme-toggle-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-full);
  color: var(--color-neutral-gray);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-neutral-light);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.theme-toggle-btn:hover {
  color: var(--color-primary-cyan-dark);
  background: var(--color-bg-tertiary);
  transform: scale(1.05);
}

.theme-icon-sun {
  display: none;
}
.theme-icon-moon {
  display: block;
}

[data-theme="dark"] .theme-icon-sun {
  display: block;
  color: var(--color-warning);
}
[data-theme="dark"] .theme-icon-moon {
  display: none;
}

/* Dark Mode Variable Overrides */
[data-theme="dark"] {
  --color-dark: #E2E8F0;            /* Body text color */
  --color-neutral-dark: #F8FAFC;    /* Heading text color */
  --color-bg-primary: #0F172A;      /* Main card content bg */
  --color-bg-secondary: #0b0f19;    /* Page background */
  --color-bg-tertiary: #1E293B;     /* Sub-backgrounds, borders */
  --color-white: #1E293B;           /* Cards, dropdowns, inputs */
  --color-neutral-light: #334155;   /* Borders, dividers */
  --color-neutral-gray: #94A3B8;    /* Muted labels & descriptions */

  /* Dark mode semantic overlays */
  --color-success-bg: rgba(16, 185, 129, 0.15);
  --color-warning-bg: rgba(245, 158, 11, 0.15);
  --color-danger-bg: rgba(239, 68, 68, 0.15);
  --color-info-bg: rgba(59, 130, 246, 0.15);
}

/* Specific component overrides for Dark Mode */
[data-theme="dark"] .app-layout {
  --layout-header-border: #2d3f5c;
}

[data-theme="dark"] .app-header {
  background: #152033;
}

/* Sidebar — dark mode */
[data-theme="dark"] .app-sidebar {
  --sidebar-text: #f1f5f9;
  --sidebar-text-muted: rgba(241, 245, 249, 0.82);
  --sidebar-icon: rgba(203, 213, 225, 0.78);
  --sidebar-border: rgba(100, 116, 139, 0.35);
  --sidebar-bg-start: #070d12;
  --sidebar-bg-mid: #0c151c;
  --sidebar-bg-end: #122229;
  --sidebar-edge: rgba(45, 63, 92, 0.75);
  --sidebar-shadow: 4px 0 24px rgba(0, 0, 0, 0.55);
  --sidebar-menu-text: rgba(226, 232, 240, 0.82);
  --sidebar-menu-hover-bg: rgba(148, 163, 184, 0.1);
  --sidebar-menu-active-text: #67e8f9;
  --sidebar-menu-active-bg: linear-gradient(135deg, rgba(34, 211, 238, 0.14) 0%, rgba(15, 118, 110, 0.22) 100%);
  --sidebar-menu-active-border: rgba(34, 211, 238, 0.28);
}

[data-theme="dark"] .sidebar-brand {
  border-bottom-color: var(--layout-header-border);
}

[data-theme="dark"] .app-layout-footer {
  background: #0b0f19;
  border-top-color: var(--layout-header-border);
}

[data-theme="dark"] .sidebar-logout-btn {
  color: rgba(203, 213, 225, 0.72);
}

[data-theme="dark"] .sidebar-logout-btn:hover {
  color: #f8fafc;
}

[data-theme="dark"] .sidebar-role--admin {
  background: rgba(251, 191, 36, 0.14);
}
[data-theme="dark"] .sidebar-role--admin .sidebar-account-role-icon,
[data-theme="dark"] .sidebar-role--admin .sidebar-account-role-label {
  color: #fcd34d;
}

[data-theme="dark"] .sidebar-role--bendahara-yayasan {
  background: rgba(56, 189, 248, 0.14);
}
[data-theme="dark"] .sidebar-role--bendahara-yayasan .sidebar-account-role-icon,
[data-theme="dark"] .sidebar-role--bendahara-yayasan .sidebar-account-role-label {
  color: #7dd3fc;
}

[data-theme="dark"] .sidebar-role--kepala-sekolah {
  background: rgba(52, 211, 153, 0.14);
}
[data-theme="dark"] .sidebar-role--kepala-sekolah .sidebar-account-role-icon,
[data-theme="dark"] .sidebar-role--kepala-sekolah .sidebar-account-role-label {
  color: #6ee7b7;
}

[data-theme="dark"] .sidebar-role--waka {
  background: rgba(167, 139, 250, 0.14);
}
[data-theme="dark"] .sidebar-role--waka .sidebar-account-role-icon,
[data-theme="dark"] .sidebar-role--waka .sidebar-account-role-label {
  color: #c4b5fd;
}

[data-theme="dark"] .sidebar-role--bendahara-sekolah {
  background: rgba(74, 222, 128, 0.14);
}
[data-theme="dark"] .sidebar-role--bendahara-sekolah .sidebar-account-role-icon,
[data-theme="dark"] .sidebar-role--bendahara-sekolah .sidebar-account-role-label {
  color: #86efac;
}

[data-theme="dark"] .sidebar-role--default {
  background: rgba(148, 163, 184, 0.12);
}
[data-theme="dark"] .sidebar-role--default .sidebar-account-role-icon,
[data-theme="dark"] .sidebar-role--default .sidebar-account-role-label {
  color: var(--sidebar-text-muted);
}

@media (max-width: 1024px) {
  [data-theme="dark"] .app-sidebar {
    border-top-color: rgba(45, 63, 92, 0.8);
    box-shadow: 0 -8px 28px rgba(0, 0, 0, 0.55);
  }
}

[data-theme="dark"] .header-picker-trigger {
  background: #152033;
  border-color: #2d3f5c;
  color: #e2e8f0;
}

[data-theme="dark"] .header-picker-text {
  color: #7dd3e8;
}

[data-theme="dark"] .header-picker-menu {
  background: #152033;
  border-color: #2d3f5c;
}

[data-theme="dark"] .header-picker-option {
  color: #e2e8f0;
}

[data-theme="dark"] .header-picker-option:hover {
  background: #1e2d46;
}

[data-theme="dark"] .header-picker-option.is-active {
  background: rgba(74, 207, 215, 0.18);
  color: #a5f3fc;
}

[data-theme="dark"] .header-picker-badge {
  background: rgba(74, 207, 215, 0.15);
  color: #7dd3e8;
}

[data-theme="dark"] .profile-dropdown {
  background: #152033;
}

[data-theme="dark"] .profile-dropdown-item {
  color: #E2E8F0;
}

[data-theme="dark"] .profile-dropdown-item:hover {
  background: #1e2d46;
}

[data-theme="dark"] .auth-card {
  background: rgba(30, 41, 59, 0.95);
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .glass-panel {
  background: rgba(15, 23, 42, 0.7);
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .card-header,
[data-theme="dark"] .card-footer {
  background: #162235;
}

[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer {
  background: #162235;
}

[data-theme="dark"] .table-responsive {
  border-color: var(--color-neutral-light);
}

[data-theme="dark"] .table th {
  background: #162235;
  color: var(--color-neutral-gray);
  border-bottom-color: var(--color-neutral-light);
}

[data-theme="dark"] .table td {
  border-bottom-color: var(--color-neutral-light);
  color: var(--color-dark);
}

[data-theme="dark"] .tabs-nav {
  border-bottom-color: var(--color-neutral-light);
}

[data-theme="dark"] .tree-content {
  border-color: var(--color-neutral-light);
}

[data-theme="dark"] .tree-content:hover {
  border-color: var(--color-primary-cyan);
}

[data-theme="dark"] .demo-toggle-btn {
  background: rgba(74, 207, 215, 0.08);
}

[data-theme="dark"] .demo-toggle-btn:hover {
  background: rgba(74, 207, 215, 0.12);
}

[data-theme="dark"] .demo-tab-btn:hover {
  background: var(--color-bg-tertiary);
}

[data-theme="dark"] .demo-account-item {
  border-color: var(--color-neutral-light);
  background: var(--color-bg-primary);
}

[data-theme="dark"] .demo-account-item:hover {
  border-color: var(--color-primary-cyan);
  background: var(--color-bg-tertiary);
}

[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: #334155;
}

[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
  background: #475569;
}

/* Kalender dark mode */
[data-theme="dark"] .kalender-nav-btn {
  background: var(--color-bg-primary);
  border-color: var(--color-neutral-light);
  color: var(--color-dark);
}

[data-theme="dark"] .kalender-nav-btn:hover {
  background: var(--color-bg-tertiary);
  border-color: var(--color-primary-cyan);
}

[data-theme="dark"] .kalender-day {
  background: var(--color-bg-primary);
  border-color: var(--color-neutral-light);
}

[data-theme="dark"] .kalender-day.is-weekend:not(.is-outside) {
  background: rgba(239, 68, 68, 0.06);
}

[data-theme="dark"] .kalender-day.is-selected {
  background: rgba(74, 207, 215, 0.12);
}

[data-theme="dark"] .kalender-day-item {
  background: var(--color-bg-primary);
  border-color: var(--color-neutral-light);
}

[data-theme="dark"] .kalender-event-chip.chip-bidang-1 { background: rgba(29, 78, 216, 0.2); color: #93C5FD; }
[data-theme="dark"] .kalender-event-chip.chip-bidang-2 { background: rgba(4, 120, 87, 0.2); color: #6EE7B7; }
[data-theme="dark"] .kalender-event-chip.chip-bidang-3 { background: rgba(180, 83, 9, 0.2); color: #FCD34D; }
[data-theme="dark"] .kalender-event-chip.chip-bidang-4 { background: rgba(109, 40, 217, 0.2); color: #C4B5FD; }
[data-theme="dark"] .kalender-event-chip.chip-bidang-5 { background: rgba(190, 24, 93, 0.2); color: #F9A8D4; }

[data-theme="dark"] .kal-rec-card,
[data-theme="dark"] .kalender-week-col,
[data-theme="dark"] .kalender-mini-month {
  background: var(--color-bg-primary);
  border-color: var(--color-neutral-light);
}

[data-theme="dark"] .kalender-week-col-head,
[data-theme="dark"] .kalender-mini-title {
  background: #162235;
}

[data-theme="dark"] .kalender-week-event.chip-bidang-1 { background: rgba(29, 78, 216, 0.2); color: #93C5FD; }
[data-theme="dark"] .kalender-week-event.chip-bidang-2 { background: rgba(4, 120, 87, 0.2); color: #6EE7B7; }
[data-theme="dark"] .kalender-week-event.chip-bidang-3 { background: rgba(180, 83, 9, 0.2); color: #FCD34D; }
[data-theme="dark"] .kalender-week-event.chip-bidang-4 { background: rgba(109, 40, 217, 0.2); color: #C4B5FD; }
[data-theme="dark"] .kalender-week-event.chip-bidang-5 { background: rgba(190, 24, 93, 0.2); color: #F9A8D4; }

/* =============================================================
   Dashboard Page
   ============================================================= */

.dash-page {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

/* Hero Banner — tone warna selaras logo (#4ACFD7 / #2BA0A8) */
.dash-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-lg);
  padding: var(--spacing-xl) var(--spacing-xl);
  border-radius: var(--radius-lg);
  background: linear-gradient(
    135deg,
    var(--color-primary-cyan-dark) 0%,
    var(--color-primary-cyan) 48%,
    #5bb8c0 100%
  );
  color: #fff;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-primary);
}

.dash-hero::before {
  content: '';
  position: absolute;
  top: -40%;
  right: -10%;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.14);
  pointer-events: none;
}

.dash-hero::after {
  content: '';
  position: absolute;
  bottom: -30%;
  left: 20%;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  pointer-events: none;
}

.dash-hero-content {
  position: relative;
  z-index: 1;
}

.dash-hero-greeting {
  font-size: var(--font-size-sm);
  opacity: 0.85;
  margin-bottom: var(--spacing-xs);
}

.dash-hero-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-md);
  color: #fff;
}

.dash-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.dash-meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.25);
  font-size: var(--font-size-xs);
  backdrop-filter: blur(4px);
}

.dash-hero-date {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.28);
  backdrop-filter: blur(8px);
  min-width: 72px;
  flex-shrink: 0;
}

.dash-date-day {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: 1;
}

.dash-date-month {
  font-size: var(--font-size-xs);
  opacity: 0.85;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-top: 4px;
}

/* Dashboard Icons (SVG + CSS) */
.dash-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-primary-cyan-dark);
}

.dash-ico svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dash-ico--sm { width: 16px; height: 16px; }
.dash-ico--md { width: 18px; height: 18px; }
.dash-ico--lg { width: 22px; height: 22px; }

/* Quick Actions */
.dash-quick-actions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-sm);
}

.dash-quick-btn {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: var(--spacing-sm);
  padding: 0.625rem 0.875rem;
  background: var(--color-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-neutral-light);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  color: var(--color-dark);
  transition: all var(--transition-fast);
}

.dash-quick-btn:hover {
  border-color: var(--color-primary-cyan);
  color: var(--color-primary-cyan-dark);
}

.dash-quick-btn:hover .dash-quick-icon {
  background: rgba(74, 207, 215, 0.18);
  color: var(--color-primary-cyan-dark);
}

.dash-quick-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  background: rgba(74, 207, 215, 0.1);
  color: var(--color-primary-cyan-dark);
  flex-shrink: 0;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.dash-quick-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-align: left;
  line-height: 1.25;
}

/* Stat Cards — compact */
.dash-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-sm);
}

.dash-stat-card {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: 0.625rem 0.75rem;
  background: var(--color-white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  border-left: 3px solid var(--color-primary-cyan);
  min-height: 0;
}

.dash-stat-card.hover-lift:hover {
  transform: translateY(-2px);
}

.dash-stat-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  background: rgba(74, 207, 215, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-primary-cyan-dark);
}

.dash-card-warning .dash-stat-icon { color: var(--color-warning); background: var(--color-warning-bg); }
.dash-card-success .dash-stat-icon { color: var(--color-success); background: var(--color-success-bg); }
.dash-card-danger .dash-stat-icon { color: var(--color-danger); background: var(--color-danger-bg); }
.dash-card-teal .dash-stat-icon { color: var(--color-accent-teal); background: rgba(31, 90, 102, 0.1); }

.dash-stat-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.dash-stat-label {
  font-size: 0.6875rem;
  color: var(--color-neutral-gray);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dash-stat-value {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-neutral-dark);
  line-height: 1.15;
}

.dash-stat-value--money {
  font-size: var(--font-size-sm);
  letter-spacing: -0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dash-stat-sub {
  font-size: 0.6875rem;
  color: var(--color-neutral-gray);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Charts */
.dash-charts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-md);
}

.dash-chart-card--wide {
  grid-column: 1 / -1;
}

.dash-chart-body {
  position: relative;
  height: 220px;
  padding: var(--spacing-sm) var(--spacing-md) var(--spacing-md);
}

.dash-chart-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  font-size: var(--font-size-sm);
  color: var(--color-neutral-gray);
  text-align: center;
  padding: var(--spacing-md);
}

@media (max-width: 768px) {
  .dash-charts-grid {
    grid-template-columns: 1fr;
  }

  .dash-chart-card--wide {
    grid-column: auto;
  }

  .dash-chart-body {
    height: 200px;
  }
}

/* Secondary Stats Bar */
.dash-secondary-stats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-md);
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-neutral-light);
  box-shadow: var(--shadow-sm);
}

.dash-secondary-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-right: var(--spacing-lg);
  border-right: 1px solid var(--color-neutral-light);
}

.dash-secondary-item:last-child {
  border-right: none;
}

.dash-secondary-item--chips {
  flex: 1;
  min-width: 200px;
}

.dash-secondary-label {
  font-size: var(--font-size-xs);
  color: var(--color-neutral-gray);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dash-secondary-value {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-neutral-dark);
}

.dash-status-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  margin-top: 4px;
}

/* Progress Bar */
.dash-progress-card {
  padding: var(--spacing-lg);
}

.dash-progress-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-sm);
}

.dash-progress-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-neutral-dark);
}

.dash-progress-pct {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-cyan-dark);
}

.dash-progress-bar {
  height: 10px;
  border-radius: var(--radius-full);
  background: var(--color-bg-tertiary);
  overflow: hidden;
}

.dash-progress-fill {
  height: 100%;
  border-radius: var(--radius-full);
  background: linear-gradient(90deg, var(--color-primary-cyan), var(--color-accent-teal));
  transition: width 0.6s ease;
}

.dash-progress-footer {
  display: flex;
  justify-content: space-between;
  margin-top: var(--spacing-sm);
  font-size: var(--font-size-xs);
  color: var(--color-neutral-gray);
}

/* Content Grid */
.dash-content-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--spacing-lg);
  align-items: start;
}

.dash-card--wide {
  grid-column: 1;
}

.dash-side-col {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

.dash-card-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-dark);
  margin: 0;
}

.dash-link {
  color: var(--color-dark);
  text-decoration: none;
}

.dash-link:hover {
  color: var(--color-primary-cyan-dark);
}

/* Timeline */
.dash-timeline {
  display: flex;
  flex-direction: column;
}

.dash-timeline-item {
  display: flex;
  gap: var(--spacing-md);
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--color-neutral-light);
  align-items: flex-start;
}

.dash-timeline-item:last-child {
  border-bottom: none;
}

.dash-timeline-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-primary-cyan);
  margin-top: 5px;
  flex-shrink: 0;
}

.dash-timeline-dot--warning { background: var(--color-warning); }
.dash-timeline-dot--success { background: var(--color-success); }
.dash-timeline-dot--danger { background: var(--color-danger); }
.dash-timeline-dot--info { background: var(--color-info); }

.dash-timeline-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dash-timeline-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-sm);
}

.dash-timeline-date {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 40px;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-bg-tertiary);
  flex-shrink: 0;
}

.dash-ev-day {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  color: var(--color-primary-cyan-dark);
}

.dash-ev-month {
  font-size: 10px;
  text-transform: uppercase;
  color: var(--color-neutral-gray);
}

/* Role distribution (admin) */
.dash-role-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-sm);
}

.dash-role-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  background: var(--color-bg-tertiary);
}

.dash-role-name {
  font-size: var(--font-size-sm);
  color: var(--color-dark);
}

.dash-role-count {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-cyan-dark);
}

/* Bidang list */
.dash-bidang-list {
  display: flex;
  flex-direction: column;
}

.dash-bidang-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-sm) var(--spacing-lg);
  border-bottom: 1px solid var(--color-neutral-light);
}

.dash-bidang-item:last-child {
  border-bottom: none;
}

.dash-bidang-name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.dash-bidang-amounts {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0;
}

.text-success {
  color: var(--color-success);
}

.text-center {
  text-align: center;
}

/* Dashboard Responsive */
@media (max-width: 1024px) {
  .dash-stats-grid,
  .dash-quick-actions {
    grid-template-columns: repeat(2, 1fr);
  }

  .dash-content-grid {
    grid-template-columns: 1fr;
  }

  .dash-side-col {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .dash-hero {
    flex-direction: column;
    align-items: flex-start;
    padding: var(--spacing-lg);
  }

  .dash-hero-date {
    flex-direction: row;
    gap: var(--spacing-sm);
    align-self: flex-end;
  }

  .dash-date-day {
    font-size: var(--font-size-xl);
  }

  .dash-stats-grid,
  .dash-quick-actions {
    grid-template-columns: 1fr 1fr;
  }

  .dash-secondary-item {
    border-right: none;
    padding-right: 0;
    width: calc(50% - var(--spacing-sm));
  }

  .dash-side-col {
    grid-template-columns: 1fr;
  }

  .dash-role-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .dash-stats-grid,
  .dash-quick-actions {
    grid-template-columns: 1fr;
  }

  .dash-secondary-item {
    width: 100%;
  }
}

/* Dark mode dashboard */
[data-theme="dark"] .dash-hero {
  background: linear-gradient(
    135deg,
    #1f6b73 0%,
    var(--color-primary-cyan-dark) 40%,
    var(--color-primary-cyan) 100%
  );
  box-shadow: 0 4px 20px rgba(74, 207, 215, 0.2);
}

[data-theme="dark"] .dash-quick-btn {
  background: var(--color-white);
  border-color: var(--color-neutral-light);
}

[data-theme="dark"] .dash-stat-card,
[data-theme="dark"] .dash-secondary-stats {
  background: var(--color-white);
  border-color: var(--color-neutral-light);
}

[data-theme="dark"] .dash-role-item,
[data-theme="dark"] .dash-timeline-date {
  background: var(--color-bg-primary);
}
