/* ─────────────────────────────────────────────────────────────────────────────
   PathwAI — Dashboard Styles
   ───────────────────────────────────────────────────────────────────────────── */

/* ══════════════════════════════════════════════════════════════════════════════
   DASHBOARD GRID LAYOUT
   ══════════════════════════════════════════════════════════════════════════════ */
.dashboard-page { padding: var(--space-6) var(--space-7); }

.stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
/* Auto 4-column when exactly 4 stat cards are present */
.stats-row:has(> .dash-stat-card:nth-child(4):last-child) {
  grid-template-columns: repeat(4, 1fr);
}

.dash-stat-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: box-shadow var(--transition-base), border-color var(--transition-base);
  position: relative;
  overflow: hidden;
  color: inherit;
  text-decoration: none;
}
.dash-stat-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-slate-300);
}
.dash-stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: var(--radius-full) var(--radius-full) 0 0;
}
.dash-stat-card.accent-blue::before   { background: var(--color-primary-500); }
.dash-stat-card.accent-green::before  { background: var(--color-emerald-500); }
.dash-stat-card.accent-amber::before  { background: var(--color-amber-500); }
.dash-stat-card.accent-red::before    { background: var(--color-red-500); }
.dash-stat-card.accent-violet::before { background: #8b5cf6; }

.dash-stat-icon {
  width: 36px; height: 36px;
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.dash-stat-icon.blue   { background: var(--color-primary-50);  color: var(--color-primary-600); }
.dash-stat-icon.green  { background: var(--color-emerald-50); color: var(--color-emerald-600); }
.dash-stat-icon.amber  { background: var(--color-amber-50);   color: var(--color-amber-600); }
.dash-stat-icon.red    { background: var(--color-red-50);     color: var(--color-red-600); }
.dash-stat-icon.violet { background: #ede9fe;                  color: #6d28d9; }

.dash-stat-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.dash-stat-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--text-muted);
}
.dash-stat-value {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--weight-extrabold);
  color: var(--text-primary);
  letter-spacing: var(--tracking-tight);
  line-height: 1;
}
.dash-stat-sublabel {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
}
.dash-stat-trend {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  margin-top: var(--space-1);
}
.dash-stat-trend.up   { color: var(--color-emerald-600); }
.dash-stat-trend.down { color: var(--color-red-600); }
.dash-stat-trend.warn { color: var(--color-amber-600); }

/* ══════════════════════════════════════════════════════════════════════════════
   MAIN GRID (2 columns: content + sidebar)
   ══════════════════════════════════════════════════════════════════════════════ */
.dashboard-main-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  align-items: start;
}
.dashboard-col-main {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.dashboard-col-side {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  position: sticky;
  top: calc(var(--topbar-height) + var(--space-6));
}

/* ══════════════════════════════════════════════════════════════════════════════
   WIDGET CARD (base)
   ══════════════════════════════════════════════════════════════════════════════ */
.widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.widget-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5) var(--space-3);
  border-bottom: 1px solid var(--border-default);
}
.widget-title {
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.widget-title svg { width: 16px; height: 16px; color: var(--text-muted); }
.widget-action {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--color-primary-600);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.widget-action:hover { color: var(--color-primary-800); }
.widget-body { padding: var(--space-4) var(--space-5); }
.widget-footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--border-default);
  background: var(--color-slate-50);
}

/* ══════════════════════════════════════════════════════════════════════════════
   ROADMAP PROGRESS WIDGET
   ══════════════════════════════════════════════════════════════════════════════ */
.roadmap-widget {}
.roadmap-timeline {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-5) var(--space-5);
  overflow-x: auto;
  scrollbar-width: none;
}
.roadmap-timeline::-webkit-scrollbar { display: none; }

.roadmap-semester {
  flex: 1;
  min-width: 100px;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.roadmap-semester-header {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--text-muted);
  text-align: center;
  padding-bottom: var(--space-2);
  border-bottom: 2px solid var(--border-default);
  white-space: nowrap;
}
.roadmap-semester.is-current .roadmap-semester-header {
  color: var(--color-primary-600);
  border-bottom-color: var(--color-primary-400);
}
.roadmap-item-chip {
  padding: 5px 8px;
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  line-height: var(--leading-snug);
  font-weight: var(--weight-medium);
  text-align: center;
  cursor: default;
  transition: all var(--transition-fast);
}
.roadmap-item-chip.type-course   { background: var(--color-primary-50);  color: var(--color-primary-700); border: 1px solid var(--color-primary-100); }
.roadmap-item-chip.type-test     { background: var(--color-amber-50);    color: var(--color-amber-800);   border: 1px solid var(--color-amber-100); }
.roadmap-item-chip.type-activity { background: var(--color-emerald-50);  color: var(--color-emerald-800); border: 1px solid var(--color-emerald-100); }
.roadmap-item-chip.type-milestone{ background: #ede9fe;                   color: #5b21b6;                  border: 1px solid #ddd6fe; }
.roadmap-item-chip.is-done { opacity: 0.55; text-decoration: line-through; }
.roadmap-item-chip.priority-high { border-left: 3px solid var(--color-red-400); }

/* ══════════════════════════════════════════════════════════════════════════════
   COLLEGE LIST WIDGET
   ══════════════════════════════════════════════════════════════════════════════ */
.college-list-widget {}
.college-list-items { display: flex; flex-direction: column; }
.college-list-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--border-default);
  text-decoration: none;
  color: inherit;
  transition: background var(--transition-fast);
}
.college-list-row:last-child { border-bottom: none; }
.college-list-row:hover { background: var(--color-slate-50); }

.college-list-category {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cat-dream   { background: #c026d3; }
.cat-reach   { background: var(--color-red-500); }
.cat-target  { background: var(--color-amber-500); }
.cat-safety  { background: var(--color-emerald-500); }

.college-list-name {
  flex: 1;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-primary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.college-list-prob {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  padding: 2px 10px;
  border-radius: var(--radius-full);
  white-space: nowrap;
  flex-shrink: 0;
}
.prob-low    { background: var(--color-red-50);     color: var(--color-red-700); }
.prob-mid    { background: var(--color-amber-50);   color: var(--color-amber-700); }
.prob-high   { background: var(--color-emerald-50); color: var(--color-emerald-700); }

.college-list-status {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════════════════════
   MINI AI COUNSELOR WIDGET (sidebar)
   ══════════════════════════════════════════════════════════════════════════════ */
.ai-widget {
  border: 1px solid var(--color-primary-200);
  background: linear-gradient(135deg, var(--color-primary-50), white);
}
.ai-widget .widget-header {
  background: var(--color-primary-600);
  border-bottom-color: var(--color-primary-700);
}
.ai-widget .widget-title { color: white; }
.ai-widget .widget-title svg { color: rgba(255,255,255,0.7); }
.ai-widget .widget-action { color: rgba(255,255,255,0.8); }
.ai-widget .widget-action:hover { color: white; }

.ai-widget-messages {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-4) var(--space-3);
  max-height: 240px;
  overflow-y: auto;
}
.ai-msg-bubble {
  background: white;
  border: 1px solid var(--color-primary-100);
  border-radius: 4px 12px 12px 12px;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--text-primary);
  line-height: var(--leading-relaxed);
  box-shadow: var(--shadow-xs);
}
.ai-msg-bubble strong { color: var(--color-primary-700); }
.ai-msg-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: 0 var(--space-4) var(--space-3);
}
.ai-suggested-prompt {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: white;
  border: 1px solid var(--color-primary-200);
  border-radius: var(--radius-lg);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-primary-700);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-align: left;
  width: 100%;
}
.ai-suggested-prompt:hover {
  background: var(--color-primary-50);
  border-color: var(--color-primary-400);
}
.ai-suggested-prompt svg { width: 12px; height: 12px; flex-shrink: 0; }
.ai-widget-input {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4) var(--space-4);
  border-top: 1px solid var(--color-primary-100);
}
.ai-widget-textbox {
  flex: 1;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  border: 1px solid var(--color-primary-200);
  border-radius: var(--radius-lg);
  background: white;
  color: var(--text-primary);
  resize: none;
  height: 38px;
  line-height: 1.4;
}
.ai-widget-textbox:focus {
  border-color: var(--color-primary-400);
  outline: none;
  box-shadow: 0 0 0 2px rgba(99,102,241,0.1);
}
.ai-widget-send {
  width: 38px; height: 38px;
  background: var(--color-primary-600);
  color: white;
  border: none;
  border-radius: var(--radius-lg);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background var(--transition-fast);
}
.ai-widget-send:hover { background: var(--color-primary-700); }
.ai-widget-send svg { width: 16px; height: 16px; }

/* ══════════════════════════════════════════════════════════════════════════════
   UPCOMING TASKS / DEADLINES WIDGET
   ══════════════════════════════════════════════════════════════════════════════ */
.task-list { display: flex; flex-direction: column; }
.task-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--border-default);
  transition: background var(--transition-fast);
  cursor: pointer;
}
.task-row:last-child { border-bottom: none; }
.task-row:hover { background: var(--color-slate-50); }

.task-checkbox {
  width: 18px; height: 18px;
  border: 1.5px solid var(--border-strong);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  margin-top: 1px;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--transition-fast);
}
.task-row.is-done .task-checkbox {
  background: var(--color-emerald-500);
  border-color: var(--color-emerald-500);
}
.task-row.is-done .task-checkbox svg { color: white; }

.task-info { flex: 1; min-width: 0; }
.task-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-primary);
  line-height: var(--leading-snug);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.task-row.is-done .task-title {
  color: var(--text-muted);
  text-decoration: line-through;
}
.task-meta {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.task-due {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  white-space: nowrap;
  flex-shrink: 0;
}
.task-due.urgent { color: var(--color-red-600); }
.task-due.soon   { color: var(--color-amber-600); }
.task-due.normal { color: var(--text-muted); }

/* Priority dot */
.task-priority {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 6px;
}
.task-priority.high   { background: var(--color-red-500); }
.task-priority.medium { background: var(--color-amber-500); }
.task-priority.low    { background: var(--color-emerald-500); }

/* ══════════════════════════════════════════════════════════════════════════════
   CREDIT WIDGET (sidebar)
   ══════════════════════════════════════════════════════════════════════════════ */
.credit-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
}
.credit-widget-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}
.credit-widget-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--text-muted);
}
.credit-widget-balance {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: var(--weight-extrabold);
  color: var(--text-primary);
  letter-spacing: var(--tracking-tight);
  line-height: 1;
  margin-bottom: var(--space-1);
}
.credit-widget-balance .unit {
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--text-secondary);
  margin-left: 4px;
}
.credit-widget-sub {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-bottom: var(--space-4);
}
.credit-widget-bar {
  height: 6px;
  background: var(--color-slate-100);
  border-radius: var(--radius-full);
  overflow: hidden;
  margin-bottom: var(--space-4);
}
.credit-widget-fill {
  height: 100%;
  border-radius: var(--radius-full);
  background: linear-gradient(90deg, var(--color-primary-500), var(--color-primary-400));
  transition: width 0.6s ease;
}
.credit-widget-fill.low    { background: linear-gradient(90deg, var(--color-red-500), var(--color-red-400)); }
.credit-widget-fill.medium { background: linear-gradient(90deg, var(--color-amber-500), var(--color-amber-400)); }

.credit-cost-table {
  display: flex;
  flex-direction: column;
  gap: var(--space-1-5);
  margin-bottom: var(--space-4);
  padding: var(--space-3);
  background: var(--color-slate-50);
  border-radius: var(--radius-lg);
}
.credit-cost-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-xs);
  color: var(--text-secondary);
}
.credit-cost-name { font-weight: var(--weight-medium); }
.credit-cost-val {
  font-weight: var(--weight-bold);
  color: var(--color-primary-700);
  background: var(--color-primary-50);
  padding: 1px 7px;
  border-radius: var(--radius-full);
}


/* ══════════════════════════════════════════════════════════════════════════════
   DASHBOARD TOPBAR EXTRAS
   ══════════════════════════════════════════════════════════════════════════════ */
.dash-topbar-student {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.dash-topbar-name {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  letter-spacing: var(--tracking-tight);
}
.dash-topbar-grade {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

/* Recent AI Insights widget */
.insight-list { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-4) var(--space-5); }
.insight-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-slate-50);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
}
.insight-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-primary-500);
  flex-shrink: 0;
  margin-top: 5px;
}
.insight-text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}
.insight-text strong { color: var(--text-primary); }
.insight-time {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: 3px;
}

/* ══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1280px) {
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .stats-row:has(> .dash-stat-card:nth-child(4):last-child) { grid-template-columns: repeat(2, 1fr); }
  .dashboard-main-grid { grid-template-columns: 1fr; }
  .dashboard-col-side { position: static; }
}
@media (max-width: 768px) {
  .dashboard-page  { padding: var(--space-4); }
  .stats-row       { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
}
@media (max-width: 480px) {
  .stats-row { grid-template-columns: 1fr 1fr; }
  .dash-stat-card { padding: var(--space-3) var(--space-4); }
  .dash-stat-value { font-size: var(--text-2xl); }
}
