/* Import DM Sans Font */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&display=swap');

/* Nextr Design System Variables */
:root {
  /* Primary Brand Colors */
  --nextr-primary: #9CAF88;
  --nextr-primary-dark: #7A8A6B;
  --nextr-primary-text: #5A6B4D;
  
  /* Secondary/Accent Colors */
  --nextr-coral: #FF6B6B;
  --nextr-light-blue: #4ECDC4;
  --nextr-charcoal: #2C3E50;
  
  /* Status Colors - Professional Traffic Light System */
  --nextr-complete: #10B981;
  --nextr-progress: #F59E0B;
  --nextr-neutral: #D1D5DB;
  
  /* Supporting Colors */
  --nextr-bg-tint: #F5F7F3;
  --nextr-text-primary: #4A4A47;
  --nextr-text-secondary: #757572;
  --nextr-text-light: #8B8B88;
  --nextr-bg-white: #FFFFFF;
  
  /* Typography */
  --nextr-text-xl: 20px;
  --nextr-text-lg: 16px;
  --nextr-text-base: 14px;
  --nextr-text-sm: 13px;
  --nextr-text-xs: 12px;
  --nextr-weight-normal: 400;
  --nextr-weight-medium: 500;
  --nextr-weight-semibold: 600;
}

/* Base Styles */
body {
  font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  font-size: var(--nextr-text-base) !important;
  line-height: 1.4 !important;
  color: var(--nextr-text-primary) !important;
  background-color: var(--nextr-bg-white) !important;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: var(--nextr-weight-semibold) !important;
  color: var(--nextr-text-primary) !important;
}

h1 { font-size: var(--nextr-text-xl) !important; }
h2 { font-size: var(--nextr-text-lg) !important; }
h3 { font-size: var(--nextr-text-base) !important; }
h4 { font-size: var(--nextr-text-base) !important; }
h5 { font-size: var(--nextr-text-sm) !important; }

/* Button Styles */
.btn-primary {
  background-color: var(--nextr-primary) !important;
  color: var(--nextr-bg-white) !important;
  font-size: var(--nextr-text-base) !important;
  font-weight: var(--nextr-weight-medium) !important;
  border: 2px solid var(--nextr-primary-dark) !important;
  padding: 8px 16px !important;
  border-radius: 4px !important;
  font-family: 'DM Sans', sans-serif !important;
}

.btn-primary:hover, .btn-primary:focus {
  background-color: var(--nextr-primary-dark) !important;
  border-color: var(--nextr-primary-dark) !important;
  color: var(--nextr-bg-white) !important;
}

.btn-secondary {
  background-color: transparent !important;
  color: var(--nextr-text-primary) !important;
  border: 2px solid var(--nextr-neutral) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: var(--nextr-weight-medium) !important;
}

.btn-secondary:hover, .btn-secondary:focus {
  background-color: var(--nextr-bg-tint) !important;
  border-color: var(--nextr-primary) !important;
  color: var(--nextr-primary-text) !important;
}

.btn-outline-secondary {
  background-color: transparent !important;
  color: var(--nextr-text-secondary) !important;
  border: 1px solid var(--nextr-neutral) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: var(--nextr-weight-normal) !important;
}

.btn-outline-secondary:hover, .btn-outline-secondary:focus {
  background-color: var(--nextr-bg-tint) !important;
  border-color: var(--nextr-primary) !important;
  color: var(--nextr-primary-text) !important;
}

/* Navigation Styles */
.sidebar {
  background: linear-gradient(180deg, var(--nextr-primary) 0%, var(--nextr-primary-dark) 100%) !important;
  color: var(--nextr-bg-white) !important;
  width: 200px !important;
  min-width: 200px !important;
  max-width: 200px !important;
  flex-shrink: 0 !important;
  height: 100vh !important;
  position: sticky !important;
  top: 0 !important;
  padding: 1rem 0 !important;
}

.nav-header {
  background-color: var(--nextr-primary) !important;
  color: var(--nextr-bg-white) !important;
  font-size: var(--nextr-text-lg) !important;
  font-weight: var(--nextr-weight-semibold) !important;
  font-family: 'DM Sans', sans-serif !important;
}

.nav-link {
  color: #ffffff !important;
  font-size: var(--nextr-text-sm) !important;
  font-weight: var(--nextr-weight-normal) !important;
  font-family: 'DM Sans', sans-serif !important;
  padding: 8px 12px !important;
  border-radius: 4px !important;
  margin: 2px 8px !important;
  white-space: normal !important;
  word-wrap: break-word !important;
  line-height: 1.3 !important;
}

.nav-link:hover, .nav-link.active {
  background-color: var(--nextr-primary-dark) !important;
  color: #ffffff !important;
}

/* Main Content Area */
.main-content {
  padding: 2rem !important;
  background-color: var(--nextr-bg-white) !important;
  min-height: 100vh !important;
}

/* Sidebar Section Headers */
.sidebar h5 {
  color: #ffffff !important;
  font-size: var(--nextr-text-sm) !important;
  font-weight: var(--nextr-weight-medium) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  margin-bottom: 8px !important;
  padding: 0 12px !important;
}

/* Sidebar Section Spacing */
.sidebar .mb-4 {
  margin-bottom: 1.5rem !important;
}

/* Status Indicators with Accessibility */
.status-complete {
  background-color: var(--nextr-complete) !important;
  color: var(--nextr-primary-text) !important;
  border-left: 4px solid var(--nextr-primary-dark) !important;
  padding: 8px 12px !important;
  border-radius: 4px !important;
}

.status-complete::before {
  content: "✓ ";
  font-weight: var(--nextr-weight-semibold);
}

.status-progress {
  background-color: var(--nextr-progress) !important;
  color: var(--nextr-charcoal) !important;
  border-left: 4px solid var(--nextr-charcoal) !important;
  padding: 8px 12px !important;
  border-radius: 4px !important;
}

.status-progress::before {
  content: "◐ ";
  font-weight: var(--nextr-weight-semibold);
}

.status-incomplete {
  background-color: var(--nextr-neutral) !important;
  color: var(--nextr-text-secondary) !important;
  border-left: 4px solid var(--nextr-text-light) !important;
  padding: 8px 12px !important;
  border-radius: 4px !important;
}

.status-incomplete::before {
  content: "○ ";
  font-weight: var(--nextr-weight-semibold);
}

/* Table Styling */
.table thead th {
  font-size: var(--nextr-text-sm) !important;
  font-weight: var(--nextr-weight-medium) !important;
  color: var(--nextr-text-secondary) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  font-family: 'DM Sans', sans-serif !important;
  background-color: var(--nextr-bg-tint) !important;
  border-bottom: 2px solid var(--nextr-neutral) !important;
  padding: 0.5rem !important;
}

/* Compact Process Instance Table */
.table td, .table th {
  padding: 0.5rem !important;
  vertical-align: middle !important;
}

.table .form-control-sm, .table .form-select-sm {
  padding: 0.25rem 0.5rem !important;
  font-size: var(--nextr-text-sm) !important;
}

.table textarea.form-control-sm {
  min-height: 32px !important;
  resize: vertical !important;
}

/* Sticky Table Headers */
.table thead.sticky-top th {
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
  background-color: var(--nextr-bg-tint) !important;
  color: var(--nextr-text-secondary) !important;
  border-bottom: 2px solid var(--nextr-neutral) !important;
  font-weight: var(--nextr-weight-medium) !important;
}

/* Admin Page Section Spacing */
.admin-section {
  margin-bottom: 3rem !important;
}

.admin-section h2, .admin-section h4 {
  color: var(--nextr-text-primary) !important;
  font-weight: var(--nextr-weight-semibold) !important;
  position: sticky !important;
  top: 0 !important;
  background-color: var(--nextr-bg-primary) !important;
  z-index: 5 !important;
  padding: 1rem 0 !important;
  margin-bottom: 1rem !important;
}

.table tbody td {
  font-size: var(--nextr-text-base) !important;
  font-weight: var(--nextr-weight-normal) !important;
  color: var(--nextr-text-primary) !important;
  font-family: 'DM Sans', sans-serif !important;
  border-bottom: 1px solid var(--nextr-neutral) !important;
}

.table-secondary {
  font-size: var(--nextr-text-sm) !important;
  color: var(--nextr-text-secondary) !important;
}

.table-metadata {
  font-size: var(--nextr-text-xs) !important;
  color: var(--nextr-text-light) !important;
}

/* Section Backgrounds */
.section-bg {
  background-color: var(--nextr-bg-tint) !important;
  border: 1px solid var(--nextr-neutral) !important;
  border-radius: 6px !important;
  padding: 1.5rem !important;
}

.card {
  background-color: var(--nextr-bg-white) !important;
  border: 1px solid var(--nextr-neutral) !important;
  border-radius: 6px !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.card-header {
  background-color: var(--nextr-bg-tint) !important;
  border-bottom: 1px solid var(--nextr-neutral) !important;
  font-weight: var(--nextr-weight-medium) !important;
  color: var(--nextr-text-primary) !important;
  font-family: 'DM Sans', sans-serif !important;
}

/* Form Controls */
.form-control {
  font-family: 'DM Sans', sans-serif !important;
  font-size: var(--nextr-text-base) !important;
  color: var(--nextr-text-primary) !important;
  border: 1px solid var(--nextr-neutral) !important;
  border-radius: 4px !important;
}

.form-control:focus {
  border-color: var(--nextr-primary) !important;
  box-shadow: 0 0 0 2px rgba(156, 175, 136, 0.25) !important;
}

.form-label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: var(--nextr-text-base) !important;
  font-weight: var(--nextr-weight-medium) !important;
  color: var(--nextr-text-primary) !important;
}

/* Accessibility Focus States */
*:focus-visible {
  outline: 3px solid #ffdd00 !important;
  outline-offset: 2px !important;
}

/* Content Header */
.content-header {
  margin-bottom: 2rem !important;
  padding-bottom: 1rem !important;
  border-bottom: 1px solid var(--nextr-neutral) !important;
}

.content-header h1, .content-header h2, .content-header h3 {
  color: var(--nextr-text-primary) !important;
  font-family: 'DM Sans', sans-serif !important;
}

/* Badge Styles */
.badge {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: var(--nextr-weight-medium) !important;
  font-size: var(--nextr-text-xs) !important;
}

.badge.bg-success {
  background-color: var(--nextr-complete) !important;
  color: var(--nextr-primary-text) !important;
}

.badge.bg-primary {
  background-color: var(--nextr-primary) !important;
  color: var(--nextr-bg-white) !important;
}

/* Text Utilities */
.text-muted {
  color: var(--nextr-text-secondary) !important;
}

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

/* Admin Section Styles */
.admin-section {
  background-color: var(--nextr-bg-white) !important;
  border: 1px solid var(--nextr-neutral) !important;
  border-radius: 6px !important;
  padding: 1.5rem !important;
  margin-bottom: 2rem !important;
}

/* Dashboard Status Colors - Nextr Brand Colors */
.task-status-box {
  width: 50px !important;
  height: 30px !important;
  border-radius: 4px !important;
  margin: 0 auto !important;
  position: relative !important;
  border-left: 4px solid transparent !important;
}

.task-status-complete {
  background-color: var(--nextr-complete) !important;
  border-left: 4px solid var(--nextr-primary-dark) !important;
}

.task-status-complete::before {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--nextr-primary-text);
  font-weight: var(--nextr-weight-semibold);
  font-size: var(--nextr-text-sm);
}

.task-status-progress {
  background-color: var(--nextr-progress) !important;
  border-left: 4px solid var(--nextr-charcoal) !important;
}

.task-status-progress::before {
  content: "◐";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--nextr-charcoal);
  font-weight: var(--nextr-weight-semibold);
  font-size: var(--nextr-text-sm);
}

.task-status-incomplete {
  background-color: var(--nextr-neutral) !important;
  border-left: 4px solid var(--nextr-text-light) !important;
}

.task-status-incomplete::before {
  content: "○";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--nextr-text-secondary);
  font-weight: var(--nextr-weight-semibold);
  font-size: var(--nextr-text-sm);
}