:root {
  --color-primary: #2563eb;
  --color-high: #16a34a;
  --color-low: #d97706;
  --color-anomaly: #9ca3af;
  --radius-card: 12px;
  --radius-button: 8px;
  --radius-input: 8px;
  --touch-target-min: 44px;
}

.counselor-text-primary {
  color: var(--color-primary);
}
.counselor-text-high {
  color: var(--color-high);
}
.counselor-text-low {
  color: var(--color-low);
}
.counselor-text-anomaly {
  color: var(--color-anomaly);
}

.counselor-bg-primary {
  background-color: var(--color-primary);
}
.counselor-bg-high {
  background-color: var(--color-high);
}
.counselor-bg-low {
  background-color: var(--color-low);
}
.counselor-bg-anomaly {
  background-color: var(--color-anomaly);
}

.counselor-empty-state {
  background-color: #f9fafb;
  border-radius: var(--radius-card);
  padding: 2rem;
  text-align: center;
  color: var(--color-anomaly);
}

.counselor-touch-target {
  min-height: 44px;
  min-width: 44px;
}

.counselor-toast-container {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 50;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.counselor-toast {
  padding: 0.75rem 1rem;
  border-radius: var(--radius-button);
  color: #fff;
  font-size: 0.875rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  animation: counselor-toast-in 0.3s ease-out;
  max-width: 24rem;
}

@keyframes counselor-toast-in {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.counselor-toast-success {
  background-color: var(--color-high);
}
.counselor-toast-warning {
  background-color: var(--color-low);
}
.counselor-toast-error {
  background-color: #dc2626;
}
.counselor-toast-info {
  background-color: var(--color-primary);
}

.counselor-stepper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.counselor-step {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  font-weight: 600;
  transition: all 0.3s;
}

.counselor-step-active {
  background-color: var(--color-high);
  color: #fff;
}

.counselor-step-completed {
  background-color: #e5e7eb;
  color: #6b7280;
}

.counselor-step-pending {
  background-color: var(--color-primary);
  color: #fff;
}

.counselor-step-line {
  width: 2rem;
  height: 2px;
  background-color: #e5e7eb;
}

.counselor-step-line-active {
  background-color: var(--color-high);
}

/* ========================================================================
   Completion Status Card
   ======================================================================== */
.counselor-completion-progress {
  height: 10px;
  border-radius: 5px;
  background-color: #e5e7eb;
  overflow: hidden;
}

.counselor-completion-progress-bar {
  height: 100%;
  border-radius: 5px;
  transition: width 0.6s ease, background-color 0.3s ease;
}

.counselor-completion-tab-btn {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: 0.5rem 0.5rem 0 0;
  transition: all 0.2s;
  cursor: pointer;
  border: none;
  background: transparent;
  color: #6b7280;
}

.counselor-completion-tab-btn:hover {
  color: #374151;
  background-color: #f3f4f6;
}

.counselor-completion-tab-btn.active {
  color: #2563eb;
  background-color: #fff;
  border-bottom: 2px solid #2563eb;
}

.counselor-completion-list {
  max-height: 280px;
  overflow-y: auto;
}

.counselor-completion-list::-webkit-scrollbar {
  width: 4px;
}

.counselor-completion-list::-webkit-scrollbar-thumb {
  background-color: #d1d5db;
  border-radius: 2px;
}

.counselor-completion-list::-webkit-scrollbar-track {
  background-color: transparent;
}

.counselor-remind-btn {
  padding: 0.25rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 500;
  border-radius: 0.375rem;
  border: 1px solid #d1d5db;
  background-color: #fff;
  color: #374151;
  cursor: pointer;
  transition: all 0.2s;
}

.counselor-remind-btn:hover {
  background-color: #f3f4f6;
  border-color: #9ca3af;
}

.counselor-remind-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.counselor-remind-btn.reminded {
  background-color: #dbeafe;
  border-color: #93c5fd;
  color: #2563eb;
}
