/* =============================================
   PM PRO — DESIGN SYSTEM
   Premium Project Management Interface
   ============================================= */

/* ── CSS Variables ── */
:root {
  --color-primary: #6366f1;
  --color-primary-dark: #4f46e5;
  --color-primary-light: #a5b4fc;
  --color-surface: #ffffff;
  --color-surface-2: #f8fafc;
  --color-surface-3: #f1f5f9;
  --color-border: #e2e8f0;
  --color-border-light: #f1f5f9;
  --color-text: #1e293b;
  --color-text-2: #475569;
  --color-text-3: #94a3b8;
  --color-sidebar-bg: #0f172a;
  --color-sidebar-text: #cbd5e1;
  --color-sidebar-active: #6366f1;
  --color-sidebar-hover: rgba(99,102,241,0.12);
  --color-success: #10b981;
  --color-warning: #f59e0b;
  --color-danger: #ef4444;
  --color-info: #06b6d4;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --sidebar-width: 240px;
  --topbar-height: 58px;
  --transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

[data-bs-theme="dark"], .dark-mode {
  --color-surface: #1e293b;
  --color-surface-2: #0f172a;
  --color-surface-3: #1e293b;
  --color-border: #334155;
  --color-border-light: #1e293b;
  --color-text: #f1f5f9;
  --color-text-2: #94a3b8;
  --color-text-3: #64748b;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.3);
}

/* ── Base ── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 14px;
  color: var(--color-text);
  background: var(--color-surface-2);
  margin: 0;
  padding: 0;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-dark); }

/* ── SIDEBAR ── */
.sidebar {
  position: fixed;
  left: 0; top: 0; bottom: 0;
  width: var(--sidebar-width);
  background: var(--color-sidebar-bg);
  display: flex;
  flex-direction: column;
  z-index: 1000;
  transition: width var(--transition), transform var(--transition);
  overflow: hidden;
}

.sidebar.collapsed {
  width: 58px;
}

.sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  min-height: 58px;
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  overflow: hidden;
}

.logo-icon {
  font-size: 22px;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-text {
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  transition: opacity var(--transition), width var(--transition);
}

.sidebar.collapsed .logo-text,
.sidebar.collapsed .nav-section-label,
.sidebar.collapsed .sidebar-footer .user-info-mini,
.sidebar.collapsed .sidebar-footer .user-actions-mini,
.sidebar.collapsed .nav-item span:not(.project-dot),
.sidebar.collapsed .nav-item-project .project-name-nav,
.sidebar.collapsed .sidebar-footer .btn-primary-custom span,
.sidebar.collapsed .nav-item-empty {
  opacity: 0;
  width: 0;
  overflow: hidden;
  pointer-events: none;
}

.sidebar-toggle-btn {
  background: none;
  border: none;
  color: #64748b;
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  flex-shrink: 0;
  transition: color var(--transition);
}
.sidebar-toggle-btn:hover { color: #fff; }

/* Nav sections */
.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px 8px;
  scrollbar-width: thin;
  scrollbar-color: #334155 transparent;
}

.nav-section {
  margin-bottom: 8px;
}

.nav-section-label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #475569;
  padding: 8px 12px 4px;
  white-space: nowrap;
  transition: opacity var(--transition);
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  color: var(--color-sidebar-text);
  font-size: 13.5px;
  font-weight: 500;
  transition: background var(--transition), color var(--transition);
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
  position: relative;
}

.nav-item svg { flex-shrink: 0; }

.nav-item:hover {
  background: var(--color-sidebar-hover);
  color: #fff;
}

.nav-item.active {
  background: var(--color-primary);
  color: #fff;
}

.nav-item-project {
  padding: 6px 12px;
  font-size: 12.5px;
}

.project-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.project-name-nav {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nav-item-empty {
  padding: 6px 12px;
  color: #475569;
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Sidebar footer */
.sidebar-footer {
  padding: 12px 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
  overflow: hidden;
}

.btn-primary-custom {
  background: var(--color-primary) !important;
  color: white !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 500 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: background var(--transition), transform var(--transition) !important;
}
.btn-primary-custom:hover {
  background: var(--color-primary-dark) !important;
  color: white !important;
  transform: translateY(-1px);
}

.user-profile-mini {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 4px 0;
  overflow: hidden;
}

.user-avatar-mini {
  width: 32px; height: 32px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  font-size: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  color: white;
}

.user-info-mini { flex: 1; overflow: hidden; }
.user-name-mini { font-size: 12.5px; font-weight: 600; color: #cbd5e1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-role-mini { font-size: 11px; color: #64748b; }

.user-actions-mini { display: flex; gap: 4px; flex-shrink: 0; }
.user-actions-mini a { color: #64748b; padding: 3px; border-radius: 4px; display: flex; }
.user-actions-mini a:hover { color: #fff; background: rgba(255,255,255,0.1); }

/* ── MAIN WRAPPER ── */
.main-wrapper {
  margin-left: var(--sidebar-width);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: margin-left var(--transition);
}

.main-wrapper.sidebar-collapsed {
  margin-left: 58px;
}

/* ── TOPBAR ── */
.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--topbar-height);
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  gap: 16px;
  box-shadow: var(--shadow-sm);
}

.topbar-left { display: flex; align-items: center; gap: 12px; flex: 1; }
.topbar-right { display: flex; align-items: center; gap: 8px; }

.breadcrumb { font-size: 13px; }
.breadcrumb-item a { color: var(--color-text-2); }
.breadcrumb-item.active { color: var(--color-text); }

.mobile-menu-btn {
  display: none;
  background: none;
  border: none;
  color: var(--color-text-2);
  cursor: pointer;
  padding: 6px;
  border-radius: var(--radius-sm);
}

/* Search */
.search-wrapper { position: relative; }
.search-input-wrap { position: relative; }
.search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--color-text-3); pointer-events: none; }
.search-input {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 7px 12px 7px 34px;
  width: 240px;
  font-size: 13px;
  color: var(--color-text);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.search-input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(99,102,241,0.12); }

/* Icon buttons */
.icon-btn {
  background: none;
  border: none;
  color: var(--color-text-2);
  cursor: pointer;
  padding: 7px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition), color var(--transition);
  position: relative;
}
.icon-btn:hover { background: var(--color-surface-3); color: var(--color-text); }
.icon-btn-sm { background: none; border: none; color: var(--color-text-3); cursor: pointer; padding: 4px; border-radius: 4px; display: flex; align-items: center; }
.icon-btn-sm:hover { color: var(--color-text); background: var(--color-surface-3); }

.notification-badge {
  position: absolute;
  top: 2px; right: 2px;
  background: var(--color-danger);
  color: white;
  font-size: 9px;
  font-weight: 700;
  border-radius: 10px;
  min-width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
}

/* Notification dropdown */
.notification-dropdown {
  width: 340px;
  max-height: 480px;
  overflow: hidden;
  flex-direction: column;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
  border-radius: var(--radius-md);
}
.notification-dropdown.show {
  display: flex;
}
.notification-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
}
.notification-list { overflow-y: auto; flex: 1; }
.notification-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-text);
  transition: background var(--transition);
}
.notification-item:hover { background: var(--color-surface-2); }
.notification-item.unread { background: rgba(99,102,241,0.04); }
.notif-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--color-surface-3);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-primary);
}
.notif-content { flex: 1; }
.notif-title { font-size: 12.5px; line-height: 1.4; }
.notif-time { font-size: 11px; color: var(--color-text-3); margin-top: 2px; }
.notification-footer { padding: 8px 16px; text-align: center; border-top: 1px solid var(--color-border); }
.notification-footer a { font-size: 13px; color: var(--color-primary); }

/* ── PAGE CONTENT ── */
.page-content { flex: 1; padding: 0; }

/* Messages */
.messages-container { padding: 12px 24px 0; }
.alert-custom {
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: var(--radius-md);
  border: none;
  font-size: 13.5px;
  padding: 10px 16px;
  box-shadow: var(--shadow-sm);
}

/* ── CARDS ── */
.card-custom {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  margin-bottom: 20px;
}

.card-header-custom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.card-title-custom {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}

.card-section-title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-3);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ── PAGE HEADER ── */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 24px 24px 16px;
  gap: 16px;
}

.page-title {
  font-size: 24px;
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
  line-height: 1.2;
}

.page-subtitle {
  color: var(--color-text-2);
  margin: 4px 0 0;
  font-size: 14px;
}

/* ── BUTTONS ── */
.btn-ghost {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text-2);
  border-radius: var(--radius-sm);
  padding: 6px 14px;
  font-size: 13px;
  cursor: pointer;
  transition: all var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn-ghost:hover { background: var(--color-surface-3); color: var(--color-text); }

.btn-outline-custom {
  background: transparent !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: var(--radius-sm) !important;
}
.btn-outline-custom:hover { background: var(--color-surface-3) !important; }

.btn-link-sm {
  background: none;
  border: none;
  color: var(--color-primary);
  font-size: 12.5px;
  cursor: pointer;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.btn-link-sm:hover { color: var(--color-primary-dark); }

.btn-clear-filter {
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 5px 10px;
  font-size: 12px;
  color: var(--color-text-2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
}
.btn-clear-filter:hover { background: var(--color-danger); color: white; border-color: var(--color-danger); }
.btn-icon-sm { color: var(--color-text-2); padding: 4px; border-radius: 4px; display: inline-flex; text-decoration: none; }
.btn-icon-sm:hover { background: var(--color-surface-3); }

/* ── FILTERS ── */
.filter-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px 16px;
  gap: 10px;
  flex-wrap: wrap;
}

.filter-form { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.filter-select {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 6px 10px;
  font-size: 13px;
  color: var(--color-text);
  outline: none;
  cursor: pointer;
}
.filter-select:focus { border-color: var(--color-primary); }

.filter-bar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.filter-check { display: flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--color-text-2); cursor: pointer; }
.filter-check input { accent-color: var(--color-primary); }

/* View tabs */
.view-tabs {
  display: flex;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  flex-shrink: 0;
}
.view-tab {
  padding: 6px 10px;
  color: var(--color-text-2);
  display: flex;
  align-items: center;
  transition: background var(--transition), color var(--transition);
}
.view-tab:hover { background: var(--color-surface-3); color: var(--color-text); }
.view-tab.active { background: var(--color-primary); color: white; }

.view-toggle { display: flex; gap: 2px; }
.view-btn { background: var(--color-surface); border: 1px solid var(--color-border); padding: 6px 10px; cursor: pointer; color: var(--color-text-2); display: flex; border-radius: 0; transition: all var(--transition); }
.view-btn:first-child { border-radius: var(--radius-sm) 0 0 var(--radius-sm); }
.view-btn:last-child { border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.view-btn.active { background: var(--color-primary); color: white; border-color: var(--color-primary); }

/* ── BADGE VARIANTS ── */
.badge-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 20px;
  white-space: nowrap;
}
.badge-planning { background: #e0f2fe; color: #0284c7; }
.badge-active { background: #dcfce7; color: #16a34a; }
.badge-on_hold { background: #fef9c3; color: #ca8a04; }
.badge-completed { background: #e0e7ff; color: #4f46e5; }
.badge-cancelled { background: #fee2e2; color: #dc2626; }
.badge-draft { background: #f1f5f9; color: #64748b; }
.badge-published { background: #dcfce7; color: #16a34a; }
.badge-overdue { background: #fee2e2; color: #dc2626; font-size: 11px; font-weight: 600; padding: 2px 7px; border-radius: 20px; display: inline-flex; align-items: center; gap: 3px; }

/* Status pills (tasks) */
.status-pill {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  white-space: nowrap;
}
.status-todo { background: #f1f5f9; color: #64748b; }
.status-in_progress { background: #dbeafe; color: #1d4ed8; }
.status-review { background: #fef3c7; color: #b45309; }
.status-done { background: #dcfce7; color: #15803d; }
.status-cancelled { background: #fee2e2; color: #991b1b; }
.status-pill-lg { font-size: 13px; padding: 4px 12px; border-radius: 20px; display: inline-block; font-weight: 600; }

/* Priority dots/badges */
.priority-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.priority-critical { background: #ef4444; }
.priority-high { background: #f97316; }
.priority-medium { background: #f59e0b; }
.priority-low { background: #94a3b8; }

.priority-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
}
.priority-badge.priority-critical { background: #fee2e2; color: #dc2626; }
.priority-badge.priority-high { background: #ffedd5; color: #c2410c; }
.priority-badge.priority-medium { background: #fef9c3; color: #b45309; }
.priority-badge.priority-low { background: #f1f5f9; color: #64748b; }

/* Team avatars */
.team-avatar, .team-avatar-sm {
  width: 28px; height: 28px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--color-surface);
  margin-left: -6px;
  font-size: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: white;
  flex-shrink: 0;
}
.team-avatar:first-child, .team-avatar-sm:first-child { margin-left: 0; }
.team-avatar-sm { width: 24px; height: 24px; font-size: 9px; }
.team-more { background: var(--color-surface-3) !important; color: var(--color-text-2); font-size: 10px; }

.avatar-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: white;
  flex-shrink: 0;
  font-size: 11px;
}
.avatar-placeholder-xs { font-size: 9px; }

/* ── DASHBOARD ── */
.dashboard-page { padding: 0; }
.dashboard-welcome {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 24px 12px;
  gap: 16px;
}

/* Stats grid */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding: 0 24px 20px;
}

.stat-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: 20px;
  border: 1px solid var(--color-border);
  display: flex;
  gap: 16px;
  align-items: flex-start;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition);
}
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.stat-icon {
  width: 44px; height: 44px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.stat-card-blue .stat-icon { background: #dbeafe; color: #1d4ed8; }
.stat-card-purple .stat-icon { background: #ede9fe; color: #7c3aed; }
.stat-card-green .stat-icon { background: #dcfce7; color: #16a34a; }
.stat-card-red .stat-icon { background: #fee2e2; color: #dc2626; }
.stat-card-amber .stat-icon { background: #fef3c7; color: #b45309; }

.stat-number { font-size: 28px; font-weight: 700; line-height: 1; margin-bottom: 4px; color: var(--color-text); }
.stat-label { font-size: 13px; font-weight: 600; color: var(--color-text-2); }
.stat-sub { font-size: 12px; color: var(--color-text-3); margin-top: 2px; }

/* Dashboard grid */
.dashboard-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 16px;
  padding: 0 24px 24px;
}
.dashboard-col-main {}
.dashboard-col-side {}

/* Project cards in dashboard */
.project-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
}

.project-card {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.project-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--color-primary); }

.project-card-header {
  padding: 16px 16px 12px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.project-card-icon {
  width: 40px; height: 40px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
}
.project-card-body { padding: 0 16px 16px; }
.project-card-key { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; margin-bottom: 4px; }
.project-card-name { font-size: 14px; font-weight: 600; color: var(--color-text); margin-bottom: 8px; line-height: 1.3; }
.project-card-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; }
.meta-item { font-size: 12px; color: var(--color-text-2); display: flex; align-items: center; gap: 4px; }

/* Progress bars */
.progress { background: var(--color-surface-3); border-radius: 100px; overflow: hidden; }
.progress-sm { height: 5px; }
.progress-xs { height: 3px; }
.progress-bar { height: 100%; border-radius: 100px; transition: width 0.6s ease; }
.project-progress-wrap { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.progress-label { font-size: 12px; color: var(--color-text-2); flex-shrink: 0; }
.project-card-team { display: flex; }

/* ── PROJECTS LIST ── */
.projects-page { padding-bottom: 32px; }
.projects-stats-bar {
  display: flex;
  gap: 24px;
  padding: 0 24px 16px;
}
.pstat { display: flex; flex-direction: column; }
.pstat-num { font-size: 22px; font-weight: 700; line-height: 1; }
.pstat-label { font-size: 12px; color: var(--color-text-2); }

.projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
  padding: 0 24px;
}
.projects-list-view { grid-template-columns: 1fr; }

.project-list-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  display: flex;
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition);
}
.project-list-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.plc-accent { width: 4px; flex-shrink: 0; }
.plc-body { padding: 16px; flex: 1; }
.plc-header { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; flex-wrap: wrap; }
.plc-key-badge { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 20px; border: 1px solid; }
.plc-title { font-size: 16px; font-weight: 600; color: var(--color-text); display: block; margin-bottom: 4px; line-height: 1.3; }
.plc-title:hover { color: var(--color-primary); }
.plc-desc { font-size: 13px; color: var(--color-text-2); margin-bottom: 10px; line-height: 1.5; }
.plc-progress { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.plc-footer { display: flex; justify-content: space-between; align-items: center; }
.plc-stats { display: flex; gap: 12px; }
.plc-stat { font-size: 12px; color: var(--color-text-2); display: flex; align-items: center; gap: 4px; }
.plc-team { display: flex; }

/* ── KANBAN ── */
.kanban-header { background: var(--color-surface); border-bottom: 1px solid var(--color-border); }
.kanban-title { font-size: 20px; font-weight: 700; color: var(--color-text); margin: 0; }
.kanban-meta { display: flex; align-items: center; gap: 12px; margin-top: 4px; flex-wrap: wrap; }
.kanban-deadline { font-size: 13px; color: var(--color-text-2); display: flex; align-items: center; gap: 4px; }
.kanban-progress-mini { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--color-text-2); }
.project-badge-kanban { padding: 8px 12px; border-radius: var(--radius-sm); }
.project-key-kanban { font-size: 18px; font-weight: 800; letter-spacing: 0.05em; }

/* Kanban columns */
.kanban-column {
  width: 290px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 160px);
}

.column-header {
  background: var(--color-surface);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  padding: 12px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 1px solid var(--color-border);
  border-bottom: none;
  position: sticky;
  top: 0;
  z-index: 10;
}
.column-title { display: flex; align-items: center; gap: 8px; }
.column-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.column-name { font-size: 13.5px; font-weight: 600; color: var(--color-text); }
.column-count { font-size: 11px; font-weight: 700; padding: 1px 7px; border-radius: 20px; }
.column-actions { display: flex; gap: 4px; }
.column-add-btn {
  width: 24px; height: 24px;
  background: var(--color-surface-3);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-3);
  font-size: 14px;
  transition: background var(--transition), color var(--transition);
}
.column-add-btn:hover { background: var(--color-primary); color: white; }

.wip-warning {
  background: #fff7ed;
  color: #c2410c;
  font-size: 11px;
  padding: 4px 14px;
  display: flex;
  align-items: center;
  gap: 4px;
  border-left: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border);
}

.kanban-tasks {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px;
  background: var(--color-surface-3);
  border: 1px solid var(--color-border);
  min-height: 100px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  scrollbar-width: thin;
}

.column-add-task-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-top: none;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  color: var(--color-text-3);
  font-size: 12.5px;
  transition: background var(--transition), color var(--transition);
}
.column-add-task-btn:hover { background: var(--color-surface-3); color: var(--color-primary); }

/* Task cards */
.task-card {
  background: var(--color-surface);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  overflow: hidden;
  cursor: grab;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  user-select: none;
  position: relative;
}
.task-card:hover { box-shadow: var(--shadow-md); border-color: var(--color-primary); transform: translateY(-1px); }
.task-card:active { cursor: grabbing; }

.task-card-overdue { border-left: 3px solid var(--color-danger) !important; }
.task-card-due-soon { border-left: 3px solid var(--color-warning) !important; }

.task-card-stripe {
  height: 3px;
  width: 100%;
}

.task-card-body { padding: 10px 12px; }
.task-card-meta-top {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.task-type-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.priority-badge { font-size: 11px; padding: 2px 6px; border-radius: 4px; display: inline-flex; align-items: center; gap: 3px; }

.blocked-badge {
  background: #fee2e2;
  color: var(--color-danger);
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
}

.task-card-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text);
  display: block;
  line-height: 1.4;
  margin-bottom: 7px;
}
.task-card-title:hover { color: var(--color-primary); }

.task-labels { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 6px; }
.task-label {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 3px;
  border: 1px solid;
  font-weight: 500;
}

.subtask-progress { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.subtask-count { font-size: 10px; color: var(--color-text-3); }

.task-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
  padding-top: 6px;
  border-top: 1px solid var(--color-border-light);
}
.task-id { font-size: 10px; color: var(--color-text-3); font-family: monospace; }
.task-footer-right { display: flex; align-items: center; gap: 6px; }

.task-due { font-size: 11px; display: flex; align-items: center; gap: 3px; color: var(--color-text-3); }
.task-due.overdue { color: var(--color-danger); font-weight: 600; }
.task-due.due-soon { color: var(--color-warning); font-weight: 600; }

.task-comment-count, .task-attach-count { font-size: 11px; color: var(--color-text-3); display: flex; align-items: center; gap: 2px; }

.task-assignees { display: flex; }
.assignee-avatar { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; border: 1.5px solid var(--color-surface); margin-left: -5px; }
.assignee-avatar:first-child { margin-left: 0; }
.assignee-avatar-xs { width: 22px; height: 22px; border-radius: 50%; font-size: 8px; font-weight: 700; color: white; margin-left: -5px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.assignee-avatar-xs:first-child { margin-left: 0; }

/* Sortable */
.sortable-ghost { opacity: 0.4; background: rgba(99,102,241,0.15) !important; border: 2px dashed var(--color-primary) !important; }
.sortable-chosen { box-shadow: var(--shadow-lg); }
.sortable-drag { opacity: 0.9; }

/* ── TASK ROWS ── */
.task-list-section { display: flex; flex-direction: column; gap: 2px; }
.task-section-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 4px 8px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}
.task-section-label.danger { background: #fee2e2; color: var(--color-danger); }
.task-section-label.warning { background: #fef3c7; color: var(--color-warning); }

.task-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: var(--radius-sm);
  color: var(--color-text);
  transition: background var(--transition);
  font-size: 13px;
}
.task-row:hover { background: var(--color-surface-2); }
.task-row-danger { background: #fff5f5; border-left: 3px solid var(--color-danger); }
.task-row-warning { background: #fffbeb; border-left: 3px solid var(--color-warning); }

.task-title-row { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.task-type-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.task-project-tag {
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 3px;
  background: color-mix(in srgb, var(--proj-color) 12%, transparent);
  color: var(--proj-color);
  flex-shrink: 0;
}
.task-due-badge {
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  gap: 3px;
  flex-shrink: 0;
  font-weight: 500;
}
.task-due-badge.overdue { background: #fee2e2; color: var(--color-danger); }
.task-due-badge.today { background: #fff7ed; color: #c2410c; }
.task-due-badge.soon { background: #fef9c3; color: #b45309; }

/* Full task rows */
.task-row-full {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-text);
  transition: background var(--transition);
}
.task-row-full:hover { background: var(--color-surface-2); }
.task-row-full.overdue { border-left: 3px solid var(--color-danger); padding-left: 13px; }
.task-row-full.due-soon { border-left: 3px solid var(--color-warning); padding-left: 13px; }
.task-type-dot-lg { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.task-row-main { flex: 1; overflow: hidden; }
.task-row-title { font-size: 13.5px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.task-row-labels { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 2px; }
.task-label-xs { font-size: 10px; padding: 1px 5px; border-radius: 3px; }
.task-due-full { font-size: 12px; display: flex; align-items: center; gap: 3px; color: var(--color-text-2); flex-shrink: 0; }
.task-due-full.overdue { color: var(--color-danger); }

/* ── DASHBOARD UPCOMING / ACTIVITY ── */
.upcoming-list { display: flex; flex-direction: column; }
.upcoming-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-text);
  text-decoration: none;
}
.upcoming-item:last-child { border-bottom: none; }
.upcoming-item:hover { color: var(--color-primary); }
.upcoming-date {
  width: 40px;
  text-align: center;
  background: var(--color-surface-2);
  border-radius: var(--radius-sm);
  padding: 6px 4px;
  flex-shrink: 0;
}
.upcoming-day { font-size: 18px; font-weight: 700; line-height: 1; color: var(--color-text); }
.upcoming-month { font-size: 10px; font-weight: 600; text-transform: uppercase; color: var(--color-text-3); }
.upcoming-info { flex: 1; overflow: hidden; }
.upcoming-title { font-size: 13px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.upcoming-project { font-size: 11px; margin-top: 2px; }

/* Activity feed */
.activity-feed { display: flex; flex-direction: column; gap: 0; }
.activity-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid var(--color-border-light);
}
.activity-item:last-child { border-bottom: none; }
.activity-avatar { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.activity-content { flex: 1; font-size: 12.5px; line-height: 1.5; }
.activity-user { font-weight: 600; }
.activity-action { color: var(--color-text-2); }
.activity-object { font-weight: 500; }
.activity-project { font-size: 11px; font-weight: 700; }
.activity-time { font-size: 11px; color: var(--color-text-3); flex-shrink: 0; white-space: nowrap; }

/* ── TASK DETAIL ── */
.task-detail-page { padding: 0 24px 32px; }
.task-detail-grid { display: grid; grid-template-columns: 1fr 280px; gap: 20px; margin-top: 16px; }
.task-detail-main {}
.task-detail-side { display: flex; flex-direction: column; gap: 0; }
.task-detail-side .card-custom { padding: 16px; margin-bottom: 12px; }

.task-detail-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
.task-breadcrumb-info { display: flex; align-items: center; gap: 8px; }
.task-id-big { font-size: 12px; font-weight: 700; color: var(--color-text-3); font-family: monospace; }
.task-type-badge-big { font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: 4px; display: inline-flex; align-items: center; gap: 4px; }
.task-header-actions { display: flex; gap: 6px; }
.task-title-big { font-size: 22px; font-weight: 700; color: var(--color-text); margin-bottom: 12px; line-height: 1.3; }

.alert-blocked { background: #fff7f7; border: 1px solid #fca5a5; border-radius: var(--radius-sm); padding: 10px 14px; font-size: 13px; color: var(--color-danger); display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }

.task-description { font-size: 14px; color: var(--color-text-2); line-height: 1.7; padding: 12px 0; border-top: 1px solid var(--color-border-light); }

.task-completion { padding: 12px 0; border-top: 1px solid var(--color-border-light); }
.form-range { accent-color: var(--color-primary); }

.subtasks-section { padding: 12px 0; border-top: 1px solid var(--color-border-light); }
.subtasks-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; font-size: 13px; }
.subtask-row { display: flex; align-items: center; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--color-border-light); color: var(--color-text); font-size: 13px; }
.status-indicator { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.status-indicator.status-done { background: var(--color-success); }
.status-indicator.status-todo { background: var(--color-text-3); }
.status-indicator.status-in_progress { background: #3b82f6; }
.subtask-title { flex: 1; }

.time-entries-section { padding: 12px 0; border-top: 1px solid var(--color-border-light); }
.time-entry-row { display: flex; align-items: center; gap: 10px; padding: 5px 0; font-size: 12.5px; }
.te-avatar { width: 24px; height: 24px; border-radius: 50%; font-size: 9px; display: flex; align-items: center; justify-content: center; font-weight: 700; color: white; }
.te-user { display: flex; align-items: center; gap: 6px; }
.te-hours { font-weight: 700; color: var(--color-primary); }
.time-summary { display: flex; align-items: center; gap: 10px; padding-top: 8px; font-size: 12px; color: var(--color-text-2); }

/* Task meta */
.task-meta-section { display: flex; flex-direction: column; gap: 10px; }
.task-meta-item { display: flex; justify-content: space-between; align-items: center; font-size: 13px; }
.meta-label { font-size: 11.5px; font-weight: 600; color: var(--color-text-3); text-transform: uppercase; letter-spacing: 0.03em; }

.column-badge-sm { font-size: 11px; padding: 2px 8px; border-radius: 4px; }
.priority-pill { font-size: 12.5px; display: inline-flex; align-items: center; gap: 4px; font-weight: 600; }

.log-time-form { margin-top: 12px; }

/* Assignees */
.assignee-row { display: flex; align-items: center; gap: 10px; padding: 6px 0; }
.assignee-avatar-md { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; font-size: 11px; display: flex; align-items: center; justify-content: center; font-weight: 700; color: white; flex-shrink: 0; }
.assignee-name { font-size: 13px; font-weight: 500; }
.assignee-role { font-size: 11px; }

/* Labels */
.labels-wrap { display: flex; flex-wrap: wrap; gap: 6px; }
.label-badge { font-size: 11.5px; padding: 2px 9px; border-radius: 4px; border: 1px solid; font-weight: 500; }

/* Comments */
.comment-form-wrap { display: flex; gap: 10px; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--color-border-light); }
.comment-avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; font-size: 11px; display: flex; align-items: center; justify-content: center; font-weight: 700; color: white; flex-shrink: 0; }
.comment-input-wrap { flex: 1; }
.comment-textarea { font-size: 13.5px; resize: none; border-color: var(--color-border); background: var(--color-surface); color: var(--color-text); }
.comment-textarea:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(99,102,241,0.1); }

.comments-list { display: flex; flex-direction: column; gap: 0; }
.comment-item { display: flex; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--color-border-light); }
.comment-item:last-child { border-bottom: none; }
.comment-content { flex: 1; }
.comment-header { display: flex; gap: 8px; align-items: center; margin-bottom: 4px; }
.comment-author { font-size: 13px; font-weight: 600; }
.comment-time { font-size: 11px; color: var(--color-text-3); }
.comment-body { font-size: 13.5px; color: var(--color-text-2); line-height: 1.6; }
.comment-body p { margin: 0; }

/* Attachments */
.attachments-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 10px; }
.attachment-card { display: flex; align-items: center; gap: 10px; padding: 10px; background: var(--color-surface-2); border-radius: var(--radius-sm); border: 1px solid var(--color-border); }
.attachment-icon { color: var(--color-primary); flex-shrink: 0; }
.attachment-info { flex: 1; overflow: hidden; }
.attachment-name { font-size: 12.5px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.attachment-meta { font-size: 11px; color: var(--color-text-3); }
.attachment-download { color: var(--color-text-3); padding: 4px; border-radius: 4px; display: flex; }
.attachment-download:hover { color: var(--color-primary); background: var(--color-surface-3); }

/* ── FORMS ── */
.form-page { padding: 24px; }
.form-container { max-width: 860px; margin: 0 auto; }
.form-page-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 24px; }
.form-title { font-size: 22px; font-weight: 700; margin: 0; }
.form-subtitle { margin: 2px 0 0; }
.form-icon { width: 44px; height: 44px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.form-section { margin-bottom: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--color-border-light); }
.form-section:last-of-type { border-bottom: none; }
.section-title { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-3); margin-bottom: 16px; }
.form-actions { display: flex; justify-content: flex-end; gap: 10px; padding-top: 16px; border-top: 1px solid var(--color-border-light); margin-top: 8px; }

/* Form controls */
.form-control, .form-select {
  background: var(--color-surface) !important;
  border-color: var(--color-border) !important;
  color: var(--color-text) !important;
  font-size: 13.5px;
  border-radius: var(--radius-sm) !important;
  transition: border-color var(--transition), box-shadow var(--transition) !important;
}
.form-control:focus, .form-select:focus {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
  outline: none !important;
}

/* Upload zone */
.upload-zone {
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-md);
  padding: 32px;
  text-align: center;
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition);
  margin-bottom: 16px;
}
.upload-zone:hover, .upload-zone.drag-over {
  border-color: var(--color-primary);
  background: rgba(99,102,241,0.04);
}
.upload-zone-content { pointer-events: none; }
.selected-file-info { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 10px; background: var(--color-surface-2); border-radius: var(--radius-sm); }

/* ── NOTES ── */
.notes-page { padding: 0 0 32px; }
.notes-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; padding: 0 24px; }
.note-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  padding: 16px;
  transition: transform var(--transition), box-shadow var(--transition);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.note-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.note-type-badge { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 20px; display: inline-flex; align-items: center; gap: 4px; width: fit-content; }
.note-type-meeting { background: #dbeafe; color: #1d4ed8; }
.note-type-standup { background: #dcfce7; color: #15803d; }
.note-type-retrospective { background: #ede9fe; color: #7c3aed; }
.note-type-planning { background: #fef9c3; color: #b45309; }
.note-type-review { background: #ffedd5; color: #c2410c; }
.note-type-brainstorm { background: #fce7f3; color: #9d174d; }
.note-type-decision { background: #f0fdf4; color: #15803d; }
.note-type-other { background: var(--color-surface-3); color: var(--color-text-2); }

.note-title { font-size: 15px; font-weight: 600; color: var(--color-text); line-height: 1.3; }
.note-title:hover { color: var(--color-primary); }
.note-meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: 12px; color: var(--color-text-3); }
.note-meta span { display: flex; align-items: center; gap: 4px; }
.note-preview { font-size: 13px; color: var(--color-text-2); line-height: 1.5; flex: 1; }
.note-footer { display: flex; justify-content: space-between; align-items: center; margin-top: 4px; }
.note-attendees { display: flex; }

/* Note detail */
.note-detail-page { padding: 0 24px 32px; }
.note-detail-grid { display: grid; grid-template-columns: 1fr 260px; gap: 20px; margin-top: 16px; }
.note-detail-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 16px; }
.note-title-big { font-size: 22px; font-weight: 700; margin: 8px 0; }
.note-detail-meta { display: flex; flex-wrap: wrap; gap: 12px; font-size: 13px; color: var(--color-text-2); }
.note-detail-meta span { display: flex; align-items: center; gap: 4px; }
.note-section { margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--color-border-light); }
.note-section:last-child { border-bottom: none; }
.note-section-title { font-size: 14px; font-weight: 600; display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.note-content-block { font-size: 14px; color: var(--color-text-2); line-height: 1.7; }
.note-content-block p { margin: 0 0 8px; }
.decisions-block { background: #f0fdf4; border-left: 3px solid var(--color-success); padding: 12px 16px; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }

/* Action items */
.action-item-row { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--color-border-light); font-size: 13px; }
.action-status-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.action-status-dot.status-done { background: var(--color-success); }
.action-status-dot.status-pending { background: var(--color-text-3); }
.action-status-dot.status-in_progress { background: #3b82f6; }
.action-info { flex: 1; }
.action-desc { line-height: 1.4; }
.action-due { flex-shrink: 0; }
.related-task-row { display: flex; align-items: center; gap: 8px; padding: 6px 0; font-size: 12.5px; color: var(--color-text); border-bottom: 1px solid var(--color-border-light); }

/* ── FILES ── */
.files-page { padding: 0 0 32px; }
.files-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; padding: 0 24px; }
.file-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform var(--transition), box-shadow var(--transition);
}
.file-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.file-icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  align-self: flex-start;
}
.file-icon-image { background: #fce7f3; color: #be185d; }
.file-icon-document { background: #dbeafe; color: #1d4ed8; }
.file-icon-spreadsheet { background: #dcfce7; color: #16a34a; }
.file-icon-presentation { background: #ffedd5; color: #c2410c; }
.file-icon-archive { background: #fef3c7; color: #b45309; }
.file-icon-video { background: #ede9fe; color: #7c3aed; }
.file-icon-other { background: var(--color-surface-3); color: var(--color-text-2); }
.file-preview-img { width: 100%; height: 100%; object-fit: cover; }
.file-info { flex: 1; }
.file-name { font-size: 13px; font-weight: 600; line-height: 1.3; }
.file-meta { font-size: 11px; color: var(--color-text-3); margin-top: 4px; display: flex; gap: 8px; }
.file-linked { margin-top: 4px; }
.file-actions { display: flex; gap: 6px; justify-content: flex-end; }

/* ── MEMBERS ── */
.members-page { padding: 0 24px 32px; }
.members-list { display: flex; flex-direction: column; }
.member-row { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--color-border-light); }
.member-row:last-child { border-bottom: none; }
.owner-row { background: rgba(99,102,241,0.03); padding: 12px; border-radius: var(--radius-sm); margin-bottom: 8px; }
.member-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.member-info { flex: 1; }
.member-name { font-size: 14px; font-weight: 600; }
.member-role-badge { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 20px; flex-shrink: 0; }
.role-admin { background: #e0e7ff; color: #4f46e5; }
.role-manager { background: #dbeafe; color: #1d4ed8; }
.role-developer { background: #dcfce7; color: #16a34a; }
.role-viewer { background: #f1f5f9; color: #64748b; }

/* ── AUTH PAGES ── */
.auth-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; background: linear-gradient(135deg, #0f172a 0%, #1e1b4b 50%, #312e81 100%); }
.auth-background { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.auth-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.15;
}
.auth-orb-1 { width: 500px; height: 500px; background: #6366f1; top: -100px; right: -100px; }
.auth-orb-2 { width: 400px; height: 400px; background: #8b5cf6; bottom: -100px; left: -100px; }
.auth-orb-3 { width: 300px; height: 300px; background: #ec4899; top: 50%; left: 40%; }

.auth-container { position: relative; z-index: 1; width: 100%; max-width: 420px; padding: 20px; }
.auth-card {
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(20px);
  border-radius: var(--radius-lg);
  padding: 40px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.3);
}
[data-bs-theme="dark"] .auth-card { background: rgba(30,41,59,0.96); }

.auth-card-header { text-align: center; margin-bottom: 28px; }
.auth-logo { font-size: 44px; margin-bottom: 8px; }
.auth-title { font-size: 26px; font-weight: 800; color: var(--color-text); margin: 0 0 4px; }
.auth-subtitle { font-size: 14px; color: var(--color-text-2); margin: 0; }

.form-group-auth { margin-bottom: 16px; }
.form-label-auth { font-size: 13px; font-weight: 600; color: var(--color-text); margin-bottom: 6px; display: block; }
.input-icon-wrap { position: relative; }
.input-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--color-text-3); pointer-events: none; }
.input-icon-wrap .form-control { padding-left: 34px !important; }

.btn-auth {
  width: 100%;
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--radius-sm);
  padding: 12px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
  transition: background var(--transition), transform var(--transition);
}
.btn-auth:hover { background: var(--color-primary-dark); transform: translateY(-1px); }

.auth-error { background: #fee2e2; color: #dc2626; border-radius: var(--radius-sm); padding: 10px 14px; font-size: 13px; display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.auth-footer { text-align: center; margin-top: 20px; font-size: 13.5px; color: var(--color-text-2); }
.auth-footer a { color: var(--color-primary); font-weight: 600; }
.auth-demo-creds { text-align: center; padding: 10px; background: var(--color-surface-2); border-radius: var(--radius-sm); margin-top: 16px; color: var(--color-text-2); }

/* ── EMPTY STATES ── */
.empty-state {
  text-align: center;
  padding: 48px 24px;
  color: var(--color-text-2);
}
.empty-state-icon { font-size: 48px; margin-bottom: 16px; }
.empty-state h3 { font-size: 18px; font-weight: 600; color: var(--color-text); margin-bottom: 8px; }
.empty-state p { font-size: 14px; color: var(--color-text-2); margin-bottom: 20px; }
.empty-state-sm { text-align: center; padding: 24px; color: var(--color-text-3); font-size: 13px; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.col-span-full { grid-column: 1 / -1; }

/* Modal */
.modal-custom { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.modal-custom .modal-header { border-bottom-color: var(--color-border); }
.modal-custom .modal-footer { border-top-color: var(--color-border); }

/* ── RESPONSIVE ── */
@media (max-width: 1200px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .dashboard-grid { grid-template-columns: 1fr; }
  .task-detail-grid { grid-template-columns: 1fr; }
  .note-detail-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  :root { --sidebar-width: 240px; }
  .sidebar { transform: translateX(-100%); }
  .sidebar.mobile-open { transform: translateX(0); }
  .main-wrapper { margin-left: 0; }
  .main-wrapper.sidebar-collapsed { margin-left: 0; }
  .mobile-menu-btn { display: flex; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .projects-grid { grid-template-columns: 1fr; }
  .page-header { flex-direction: column; padding: 16px; }
  .page-content { padding: 0; }
  .kanban-board { padding: 0 12px 12px; }
  .kanban-column { width: 260px; }
  .dashboard-grid { padding: 0 16px 16px; }
  .projects-grid { padding: 0 16px; }
  .filter-row { padding: 0 16px 12px; }
}

/* ── GLOBAL SEARCH MODAL ── */
#globalSearchModal .modal-dialog { max-width: 560px; margin-top: 80px; }
#globalSearchModal .modal-content { background: var(--card-bg); border: 1px solid var(--border-color); border-radius: 14px; box-shadow: 0 20px 60px rgba(0,0,0,.3); }
#globalSearchModal .modal-body { padding: 0; }
.search-modal-input-wrap { display: flex; align-items: center; gap: 10px; padding: 14px 18px; border-bottom: 1px solid var(--border-color); }
.search-modal-input-wrap i { color: var(--text-muted); flex-shrink: 0; }
#globalSearchInput { border: none; background: transparent; outline: none; font-size: 16px; color: var(--text-color); width: 100%; }
#globalSearchInput::placeholder { color: var(--text-muted); }
#searchResultsList { max-height: 380px; overflow-y: auto; padding: 8px; }
.search-result-item { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 8px; cursor: pointer; text-decoration: none; color: var(--text-color); transition: background .12s; }
.search-result-item:hover { background: var(--bg-secondary); color: var(--text-color); }
.search-result-icon { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 14px; }
.search-result-info { flex: 1; min-width: 0; }
.search-result-title { font-weight: 500; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.search-result-subtitle { font-size: 12px; color: var(--text-muted); }
.search-hints { display: flex; gap: 16px; padding: 10px 18px; border-top: 1px solid var(--border-color); }
.search-hint { font-size: 11px; color: var(--text-muted); display: flex; align-items: center; gap: 4px; }
.search-hint kbd { background: var(--bg-secondary); border: 1px solid var(--border-color); border-radius: 4px; padding: 1px 5px; font-size: 10px; font-family: monospace; }
.search-trigger { display: flex; align-items: center; gap: 8px; padding: 6px 12px; background: var(--bg-secondary); border: 1px solid var(--border-color); border-radius: 8px; cursor: pointer; color: var(--text-muted); font-size: 13px; transition: border-color .15s; }
.search-trigger:hover { border-color: var(--primary-color); }
.search-trigger kbd { background: var(--card-bg); border: 1px solid var(--border-color); border-radius: 4px; padding: 1px 5px; font-size: 10px; margin-left: auto; }

/* ── WORKLOAD TAGS ── */
.workload-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px; }
.workload-tag { font-size: 11px; padding: 2px 7px; border-radius: 12px; font-weight: 500; }
.workload-tag.active { background: #3b82f622; color: #3b82f6; }
.workload-tag.overdue { background: #ef444422; color: #ef4444; }
.workload-tag.done { background: #10b98122; color: #10b981; }
.member-workload { padding: 4px 0 8px 0; }

/* ── TEMPLATE PICKER (project create) ── */
.template-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; margin-bottom: 20px; }
.template-card { position: relative; }
.template-card input[type="radio"] { position: absolute; opacity: 0; }
.template-card-label { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 16px 12px; border: 2px solid var(--border-color); border-radius: 12px; cursor: pointer; transition: border-color .15s, background .15s; text-align: center; }
.template-card-label:hover { border-color: var(--primary-color); background: var(--primary-color)08; }
.template-card input[type="radio"]:checked + .template-card-label { border-color: var(--primary-color); background: var(--primary-color)11; }
.template-icon { font-size: 28px; line-height: 1; }
.template-name { font-size: 13px; font-weight: 600; color: var(--text-color); }
.template-desc { font-size: 11px; color: var(--text-muted); }

/* ── TIMER WIDGET ── */
.timer-display { font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 28px; font-weight: 700; text-align: center; color: var(--text-color); letter-spacing: 2px; padding: 8px 0 4px; line-height: 1; }
.pomodoro-display { font-family: monospace; font-size: 32px; font-weight: 700; color: #f59e0b; letter-spacing: 2px; }

/* ── BACKLOG ── */
.backlog-task-row .priority-dot { flex-shrink: 0; }
.backlog-group-header .badge { border-radius: 20px; font-weight: 500; }
.backlog-task-list .backlog-task-row:hover { color: var(--text-color); }

/* ── MENTION DROPDOWN ── */
.mention-item:hover, .mention-item.active { background: var(--bg-secondary) !important; }

/* ── UTILITIES ── */
.btn-xs { padding: 2px 6px; font-size: 11px; line-height: 1.5; border-radius: 5px; }
