/* app.css — iCS Job Tracker v4 Solvior Component Styles */

/* ===== LOGIN ===== */
.login-screen {
  min-height: 100dvh; display: flex; align-items: center; justify-content: center;
  background: var(--color-bg); padding: var(--space-4);
  position: relative; overflow: hidden;
}
.login-screen::before {
  content: ''; position: absolute; top: -30%; right: -20%; width: 60vw; height: 60vw;
  background: radial-gradient(circle, rgba(26,154,181,0.06) 0%, transparent 70%);
  pointer-events: none;
}
.login-screen::after {
  content: ''; position: absolute; bottom: -20%; left: -10%; width: 40vw; height: 40vw;
  background: radial-gradient(circle, rgba(27,54,93,0.08) 0%, transparent 70%);
  pointer-events: none;
}
.login-screen[hidden] { display: none; }
.login-card {
  width: 100%; max-width: 400px; background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl); padding: var(--space-10); box-shadow: var(--shadow-lg);
  position: relative; z-index: 1;
  opacity: 0; transform: translateY(20px);
}
.login-logo { text-align: center; margin-bottom: var(--space-8); }
.login-logo-img {
  width: 56px; height: 56px; object-fit: contain; margin: 0 auto var(--space-4); display: block;
  border-radius: var(--radius-lg);
}
.login-title {
  font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--color-text);
  margin-bottom: var(--space-1); letter-spacing: -0.3px;
}
.login-subtitle { font-size: var(--text-sm); color: var(--color-text-muted); font-family: var(--font-body); }
.login-form { display: flex; flex-direction: column; gap: var(--space-4); }
.login-error {
  font-size: var(--text-sm); color: var(--color-error); background: var(--color-error-highlight);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); text-align: center;
}

/* ===== FORMS ===== */
.form-group { display: flex; flex-direction: column; gap: var(--space-1); }
.form-group label {
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.6px;
}
.form-group input, .form-group textarea, .form-group select {
  padding: var(--space-2) var(--space-3); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md); background: var(--color-bg); font-size: var(--text-sm);
  color: var(--color-text); font-family: var(--font-body);
  transition: border-color var(--transition-interactive), box-shadow var(--transition-interactive);
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px var(--teal-subtle);
}
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--color-text-faint); }
.form-group textarea { resize: vertical; min-height: 72px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.req { color: var(--color-error); }

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md); font-size: var(--text-sm); font-weight: 600; cursor: pointer; border: none;
  transition: all var(--transition-interactive); white-space: nowrap;
  font-family: var(--font-display); letter-spacing: 0.2px;
}
.btn-primary {
  background: var(--teal); color: #fff;
  box-shadow: 0 2px 8px rgba(26,154,181,0.2);
}
.btn-primary:hover {
  background: var(--teal-hover); box-shadow: 0 4px 12px rgba(26,154,181,0.3);
  transform: translateY(-1px);
}
.btn-accent {
  background: var(--teal); color: #fff;
  box-shadow: 0 2px 8px rgba(26,154,181,0.2);
}
.btn-accent:hover {
  background: var(--teal-hover); box-shadow: 0 4px 12px rgba(26,154,181,0.3);
}
.btn-ghost {
  background: transparent; color: var(--color-text-muted); border: 1px solid var(--color-border-subtle);
}
.btn-ghost:hover { background: var(--color-surface-dynamic); color: var(--color-text); }
.btn-danger { background: var(--color-error); color: #fff; }
.btn-danger:hover { background: var(--color-error-hover); }
.btn-full { width: 100%; justify-content: center; }
.btn-sm { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); }
.btn-icon {
  display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px;
  border-radius: var(--radius-md); color: var(--color-text-muted); background: transparent; border: none; cursor: pointer;
  transition: all var(--transition-interactive);
}
.btn-icon:hover { background: var(--color-surface-dynamic); color: var(--teal); }

/* ===== APP LAYOUT ===== */
.app-screen { display: flex; min-height: 100dvh; background: var(--color-bg); }
.app-screen[hidden] { display: none; }

/* ===== SIDEBAR — Solvior dark charcoal ===== */
.sidebar {
  width: var(--sidebar-width); background: #111420;
  display: flex; flex-direction: column; position: fixed; top: 0; left: 0; bottom: 0; z-index: 60;
  overflow-y: auto; border-right: 1px solid rgba(255,255,255,0.04);
}
.sidebar-header {
  display: flex; align-items: center; gap: var(--space-3); padding: var(--space-6) var(--space-5);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.sidebar-logo-img {
  width: 32px; height: 32px; object-fit: contain; flex-shrink: 0; border-radius: var(--radius-md);
}
.sidebar-brand {
  font-family: var(--font-display); font-size: var(--text-sm); font-weight: 700; color: #fff;
  white-space: nowrap; letter-spacing: -0.2px;
}
.sidebar-nav {
  flex: 1; padding: var(--space-4) var(--space-3); display: flex; flex-direction: column; gap: 2px;
}
.nav-item {
  display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md); color: rgba(255,255,255,0.5); font-size: var(--text-sm); font-weight: 500;
  cursor: pointer; background: none; border: none; width: 100%; text-align: left;
  transition: all var(--transition-interactive); font-family: var(--font-body); position: relative;
}
.nav-item:hover { background: rgba(255,255,255,0.05); color: rgba(255,255,255,0.85); }
.nav-item.active {
  background: rgba(26,154,181,0.1); color: var(--teal); font-weight: 600;
}
.nav-item.active::before {
  content: ''; position: absolute; left: 0; top: 8px; bottom: 8px; width: 3px;
  background: var(--teal); border-radius: 0 3px 3px 0;
}
.nav-badge {
  background: var(--teal); color: #fff; font-size: 10px; font-weight: 700;
  padding: 1px 7px; border-radius: var(--radius-full); margin-left: auto;
}
.nav-item-logout { margin-top: auto; }
.sidebar-footer {
  padding: var(--space-3) var(--space-3); border-top: 1px solid rgba(255,255,255,0.06);
}
.sidebar-user {
  display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-2);
}
.user-avatar {
  width: 32px; height: 32px; border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--teal), var(--navy)); color: #fff;
  display: flex; align-items: center; justify-content: center; font-weight: 700;
  font-size: var(--text-sm); flex-shrink: 0;
}
.user-info { display: flex; flex-direction: column; min-width: 0; }
.user-name {
  font-family: var(--font-display); font-size: var(--text-sm); font-weight: 600; color: #fff;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.user-role {
  font-size: 10px; color: rgba(255,255,255,0.35); text-transform: uppercase;
  letter-spacing: 0.8px; font-family: var(--font-body);
}

/* Mobile hamburger */
.mobile-menu-btn {
  display: none; position: fixed; top: var(--space-3); left: var(--space-3); z-index: 70;
  background: var(--color-surface); color: var(--color-text); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md); width: 40px; height: 40px;
  align-items: center; justify-content: center; cursor: pointer;
}

/* ===== MAIN CONTENT ===== */
.main-content {
  margin-left: var(--sidebar-width); flex: 1; display: flex; flex-direction: column;
  min-height: 100dvh; min-width: 0;
}

/* ===== TOP BAR — Solvior sticky with subtle border ===== */
.top-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-6); background: var(--color-surface);
  border-bottom: 1px solid var(--color-border-subtle); position: sticky; top: 0; z-index: 40;
  gap: var(--space-3); backdrop-filter: blur(12px);
}
.top-bar-left { display: flex; align-items: center; gap: var(--space-4); min-width: 0; }
.top-bar-right { display: flex; align-items: center; gap: var(--space-3); }
.page-title {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700;
  color: var(--color-text); letter-spacing: -0.3px;
}
.client-name {
  font-size: var(--text-xs); font-weight: 600; color: var(--teal);
  padding: var(--space-1) var(--space-3); background: var(--teal-subtle);
  border-radius: var(--radius-full); white-space: nowrap; font-family: var(--font-display);
  letter-spacing: 0.3px;
}

.client-selector-wrap[hidden] { display: none; }
.client-selector {
  padding: var(--space-1) var(--space-3); padding-right: var(--space-8);
  border: 1px solid var(--color-border-subtle); border-radius: var(--radius-md);
  background: var(--color-bg); font-size: var(--text-sm); font-weight: 500; color: var(--color-text);
  cursor: pointer; appearance: none; -webkit-appearance: none; min-width: 180px;
  font-family: var(--font-body);
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23505872' stroke-width='2' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 8px center;
}
.client-selector:focus { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px var(--teal-subtle); }

/* ===== KANBAN BOARD ===== */
.page { flex: 1; }
.page[hidden] { display: none; }

#page-jobs {
  background: var(--board-bg); padding: var(--space-5); overflow-x: auto;
  position: relative;
}

.kanban-board {
  display: flex; gap: var(--space-4); min-height: calc(100dvh - 140px); align-items: flex-start;
}
.kanban-column {
  flex: 0 0 260px; background: var(--board-column-bg); border-radius: var(--radius-lg);
  display: flex; flex-direction: column; max-height: calc(100dvh - 160px);
  border: 1px solid rgba(255,255,255,0.04);
  opacity: 0; transform: translateY(12px);
}
.column-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-4); background: var(--board-column-header);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  border-bottom: 2px solid var(--teal);
}
.column-header h3 {
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 700;
  color: var(--board-text); text-transform: uppercase; letter-spacing: 0.8px;
}
.column-count {
  font-size: 11px; font-weight: 700; color: var(--teal);
  background: var(--teal-subtle); padding: 2px 8px; border-radius: var(--radius-full);
  font-family: var(--font-display);
}

.column-cards {
  flex: 1; overflow-y: auto; padding: var(--space-2); display: flex;
  flex-direction: column; gap: var(--space-2); min-height: 60px;
}
.column-cards::-webkit-scrollbar { width: 3px; }
.column-cards::-webkit-scrollbar-track { background: transparent; }
.column-cards::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 4px; }

/* ===== KANBAN CARD — Solvior elevated surface ===== */
.kanban-card {
  background: var(--color-surface); border-radius: var(--radius-md); padding: var(--space-3);
  cursor: grab; transition: all var(--transition-interactive);
  user-select: none; box-shadow: var(--shadow-card);
  border: 1px solid var(--color-border-subtle);
  position: relative;
}
.kanban-card:hover {
  box-shadow: var(--shadow-md), var(--shadow-glow);
  transform: translateY(-2px); border-color: rgba(26,154,181,0.3);
}
.kanban-card:active { cursor: grabbing; }
.kanban-card.dragging { opacity: 0.5; transform: rotate(2deg); box-shadow: var(--shadow-lg); }
.card-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 2px; }
.card-company {
  font-family: var(--font-display); font-size: var(--text-sm); font-weight: 700;
  color: var(--color-text); letter-spacing: -0.1px;
}
.card-icons { display: flex; gap: 4px; align-items: center; flex-shrink: 0; }
.card-icon-btn {
  color: var(--color-text-faint); display: inline-flex; background: none; border: none;
  cursor: pointer; padding: 2px;
}
.card-icon-btn:hover { color: var(--teal); }
.card-title {
  font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-2);
  font-family: var(--font-body);
}
.card-meta { display: flex; align-items: center; justify-content: space-between; }
.card-date { font-size: 11px; color: var(--color-text-faint); font-family: var(--font-body); }
.card-stars { display: flex; gap: 1px; }
.card-star { color: var(--gold); font-size: 12px; line-height: 1; }
.card-star.empty { color: var(--color-text-faint); opacity: 0.3; }

/* Drag states */
.column-cards.drag-over { background: var(--teal-subtle); border-radius: var(--radius-md); }
.drop-indicator { height: 3px; background: var(--teal); border-radius: 2px; margin: 2px 0; box-shadow: 0 0 8px var(--teal-glow); }

/* Empty column */
.empty-col {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: var(--space-8) var(--space-4); color: var(--board-text-muted);
  font-size: var(--text-xs); text-align: center; gap: var(--space-2); opacity: 0.4;
}

/* ===== STATS BAR ===== */
.stats-bar {
  display: flex; gap: var(--space-6); padding: var(--space-4) var(--space-6);
  background: var(--color-surface); border-bottom: 1px solid var(--color-border-subtle);
}
.stats-bar[hidden] { display: none; }
.stat-item {
  display: flex; flex-direction: column; gap: 2px;
}
.stat-value {
  font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 700;
  color: var(--teal); letter-spacing: -0.5px; line-height: 1;
}
.stat-label {
  font-family: var(--font-body); font-size: 11px; color: var(--color-text-faint);
  text-transform: uppercase; letter-spacing: 0.8px;
}

/* ===== MESSAGES PAGE ===== */
#page-messages { padding: var(--space-5) var(--space-6); }
.messages-toolbar { margin-bottom: var(--space-4); }
.filter-tabs { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.filter-tab {
  padding: var(--space-1) var(--space-3); border-radius: var(--radius-full); font-size: var(--text-xs);
  font-weight: 600; cursor: pointer; border: 1px solid var(--color-border-subtle); background: transparent;
  color: var(--color-text-muted); transition: all var(--transition-interactive);
  font-family: var(--font-display); letter-spacing: 0.2px;
}
.filter-tab:hover { background: var(--color-surface-dynamic); color: var(--color-text); }
.filter-tab.active {
  background: var(--teal-subtle); color: var(--teal); border-color: rgba(26,154,181,0.3);
}

.messages-list { display: flex; flex-direction: column; gap: var(--space-3); }

.message-card {
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-4); cursor: pointer;
  transition: all var(--transition-interactive);
}
.message-card:hover {
  box-shadow: var(--shadow-md), var(--shadow-glow);
  border-color: rgba(26,154,181,0.3); transform: translateY(-1px);
}
.msg-top {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: var(--space-2);
}
.msg-contact {
  font-family: var(--font-display); font-size: var(--text-sm); font-weight: 700; color: var(--color-text);
}
.msg-company { font-size: var(--text-xs); color: var(--color-text-muted); font-family: var(--font-body); }
.msg-badge {
  font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: var(--radius-full);
  text-transform: uppercase; letter-spacing: 0.3px; font-family: var(--font-display);
}
.msg-badge.pending_review { background: var(--teal-subtle); color: var(--teal); }
.msg-badge.approved { background: var(--color-success-highlight); color: var(--color-success); }
.msg-badge.revision_requested { background: var(--color-warning-highlight); color: var(--color-warning); }
.msg-badge.sent { background: var(--color-primary-highlight); color: var(--teal); }
.msg-badge.rejected { background: var(--color-error-highlight); color: var(--color-error); }
.msg-type-badge {
  font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: var(--radius-sm);
  background: var(--teal-subtle); color: var(--teal); text-transform: uppercase;
  font-family: var(--font-display); letter-spacing: 0.3px;
}
.msg-preview {
  font-size: var(--text-xs); color: var(--color-text-muted); line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  font-family: var(--font-body);
}
.msg-meta {
  display: flex; gap: var(--space-3); margin-top: var(--space-2); font-size: 11px;
  color: var(--color-text-faint); font-family: var(--font-body);
}

/* Message Detail Modal */
.modal-wide { max-width: 640px; }
.modal-sm { max-width: 400px; }
.message-detail { display: flex; flex-direction: column; gap: var(--space-4); }
.msg-detail-header {
  display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-3);
}
.msg-detail-contact {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--color-text);
}
.msg-detail-sub { font-size: var(--text-xs); color: var(--color-text-muted); font-family: var(--font-body); }
.msg-detail-body {
  background: var(--color-bg); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md); padding: var(--space-4); font-size: var(--text-sm);
  color: var(--color-text); line-height: 1.7; white-space: pre-wrap; font-family: var(--font-body);
}
.msg-detail-section { display: flex; flex-direction: column; gap: var(--space-2); }
.msg-detail-label {
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.6px;
}
.feedback-area {
  width: 100%; min-height: 80px; padding: var(--space-3); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md); background: var(--color-bg); font-size: var(--text-sm);
  color: var(--color-text); font-family: var(--font-body); resize: vertical;
}
.feedback-area:focus { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px var(--teal-subtle); }

/* Editable message body textarea for clients */
.msg-edit-body {
  width: 100%; min-height: 120px; padding: var(--space-3); border: 1px solid var(--teal);
  border-radius: var(--radius-md); background: var(--color-bg); font-size: var(--text-sm);
  color: var(--color-text); font-family: var(--font-body); resize: vertical;
  line-height: 1.6; transition: border-color 0.2s, box-shadow 0.2s;
}
.msg-edit-body:focus { outline: none; border-color: var(--teal); box-shadow: 0 0 0 3px var(--teal-subtle); }

/* Client-edited badge for admin view */
.msg-edited-badge {
  display: inline-block; margin-top: var(--space-2);
  font-size: var(--text-xs); font-weight: 600; color: var(--teal);
  padding: 2px 8px; border-radius: var(--radius-full);
  background: var(--teal-subtle); letter-spacing: 0.3px;
}

.msg-actions { display: flex; gap: var(--space-2); flex-wrap: wrap; }

/* ===== CLIENTS PAGE ===== */
#page-clients { padding: var(--space-5) var(--space-6); }
.clients-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-5); flex-wrap: wrap; gap: var(--space-3);
}
.clients-header h3 {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700;
  color: var(--color-text); letter-spacing: -0.3px;
}
.clients-header-actions { display: flex; align-items: center; gap: var(--space-3); }
.archive-toggle { display: flex; gap: var(--space-1); }
.clients-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-4);
}
.client-card {
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-5);
  transition: all var(--transition-interactive); cursor: pointer; position: relative;
}
.client-card:hover {
  box-shadow: var(--shadow-md), var(--shadow-glow);
  border-color: rgba(26,154,181,0.3); transform: translateY(-2px);
}
.client-card.archived-card { opacity: 0.6; }
.client-card.archived-card:hover { opacity: 1; }
.client-card-top {
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-2);
}
.client-card-name {
  font-family: var(--font-display); font-size: var(--text-base); font-weight: 700;
  color: var(--color-text); margin-bottom: var(--space-1);
}
.client-card-email {
  font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-3);
  font-family: var(--font-body);
}
.client-card-actions { display: flex; gap: var(--space-1); flex-shrink: 0; }
.client-card-actions .btn { font-size: var(--text-xs); padding: 2px 8px; white-space: nowrap; }
.client-card-stats { display: flex; gap: var(--space-4); }
.client-stat {
  font-size: var(--text-xs); color: var(--color-text-faint); font-family: var(--font-body);
}
.client-stat strong { color: var(--teal); font-weight: 700; }

/* ===== STAR RATING INPUT ===== */
.star-rating-input { display: flex; gap: 2px; }
.star-btn {
  font-size: 22px; color: var(--color-text-faint); opacity: 0.3; cursor: pointer; background: none;
  border: none; padding: 0; transition: all 100ms ease; line-height: 1;
}
.star-btn.active { color: var(--gold); opacity: 1; }
.star-btn:hover { color: var(--gold); opacity: 0.7; transform: scale(1.15); }

/* ===== MODALS — Solvior elevated ===== */
.modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.7); display: flex; align-items: center;
  justify-content: center; z-index: 100; padding: var(--space-4);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  animation: fadeIn 200ms ease;
}
.modal-overlay[hidden] { display: none; }
.modal {
  width: 100%; max-width: 480px; background: var(--color-surface-elevated);
  border: 1px solid var(--color-border-subtle); border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg); max-height: 90vh; overflow-y: auto;
  animation: modalEnter 300ms cubic-bezier(0.16, 1, 0.3, 1);
}
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--color-border-subtle);
}
.modal-title {
  font-family: var(--font-display); font-size: var(--text-base); font-weight: 700;
  letter-spacing: -0.2px;
}
.modal-body {
  padding: var(--space-4) var(--space-5); display: flex; flex-direction: column; gap: var(--space-3);
}
.modal-footer {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: var(--space-4); border-top: 1px solid var(--color-border-subtle);
  margin-top: var(--space-2);
}
.modal-actions { display: flex; gap: var(--space-2); }

/* ===== NOTIFICATION SETTINGS ===== */
.settings-section {
  padding: var(--space-5) var(--space-6);
}
.settings-section h3 {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700;
  color: var(--color-text); margin-bottom: var(--space-4); letter-spacing: -0.3px;
}
.toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) 0; border-bottom: 1px solid var(--color-border-subtle);
}
.toggle-row:last-child { border-bottom: none; }
.toggle-label {
  font-family: var(--font-body); font-size: var(--text-sm); color: var(--color-text);
}
.toggle-sublabel {
  font-size: var(--text-xs); color: var(--color-text-faint); margin-top: 2px;
}
/* Toggle switch */
.toggle-switch {
  position: relative; width: 40px; height: 22px; cursor: pointer;
}
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0; background: var(--color-surface-dynamic); border-radius: 11px;
  transition: all var(--transition-interactive);
}
.toggle-slider::before {
  content: ''; position: absolute; width: 16px; height: 16px; left: 3px; bottom: 3px;
  background: var(--color-text-muted); border-radius: 50%; transition: all var(--transition-interactive);
}
.toggle-switch input:checked + .toggle-slider { background: var(--teal); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(18px); background: #fff; }

/* ===== FOOTER ===== */
.app-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-6); border-top: 1px solid var(--color-border-subtle);
  background: var(--color-surface); font-size: 11px; color: var(--color-text-faint);
  margin-top: auto; font-family: var(--font-body);
}
.app-footer a { color: var(--color-text-faint); text-decoration: none; }
.app-footer a:hover { color: var(--teal); }

/* ===== TOAST — Solvior accent ===== */
.toast {
  position: fixed; bottom: var(--space-6); right: var(--space-6);
  background: var(--color-surface-elevated); color: var(--color-text);
  padding: var(--space-3) var(--space-5); border-radius: var(--radius-md);
  font-size: var(--text-sm); font-weight: 500; box-shadow: var(--shadow-lg);
  z-index: 200; border: 1px solid var(--color-border-subtle);
  border-left: 3px solid var(--teal); font-family: var(--font-body);
  animation: toastEnter 350ms cubic-bezier(0.16, 1, 0.3, 1);
}
.toast.toast-error { border-left-color: var(--color-error); }

/* ===== ANIMATIONS ===== */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalEnter { from { opacity: 0; transform: translateY(16px) scale(0.97); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes toastEnter { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }

/* ===== REPLY BUBBLES ===== */
.reply-bubble {
  padding: var(--space-3) var(--space-4); border-radius: var(--radius-lg);
  max-width: 85%; margin-bottom: var(--space-2); position: relative;
}
.reply-inbound {
  background: var(--color-surface-dynamic); border: 1px solid var(--color-border-subtle);
  align-self: flex-start; border-bottom-left-radius: var(--radius-sm);
}
.reply-outbound {
  background: rgba(26,154,181,0.1); border: 1px solid rgba(26,154,181,0.2);
  align-self: flex-end; margin-left: auto; border-bottom-right-radius: var(--radius-sm);
}
.reply-sender {
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 700;
  color: var(--teal); margin-bottom: 2px;
}
.reply-outbound .reply-sender { color: var(--color-text-muted); }
.reply-body {
  font-size: var(--text-sm); color: var(--color-text); line-height: 1.6;
  font-family: var(--font-body); white-space: pre-wrap;
}
.reply-time {
  font-size: 10px; color: var(--color-text-faint); margin-top: 4px;
  font-family: var(--font-body);
}
#reply-thread {
  display: flex; flex-direction: column; gap: var(--space-2);
  max-height: 300px; overflow-y: auto; padding: var(--space-2) 0;
}
.msg-reply-badge {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 10px; font-weight: 600; color: var(--teal);
  background: var(--teal-subtle); padding: 2px 7px; border-radius: var(--radius-full);
  font-family: var(--font-display);
}
.reply-unread-dot {
  display: inline-block; width: 6px; height: 6px; background: var(--teal);
  border-radius: 50%; animation: pulse 1.5s infinite;
}
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* ===== CONVERSATIONS PAGE ===== */
#page-conversations { padding: var(--space-5) var(--space-6); }
.conversations-header { margin-bottom: var(--space-5); }
.conversations-header h3 {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700;
  color: var(--color-text); letter-spacing: -0.3px;
}
.conversations-subtitle {
  font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1);
  font-family: var(--font-body);
}
.conversations-list { display: flex; flex-direction: column; gap: var(--space-3); }
.conversation-card {
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-4); cursor: pointer;
  transition: all var(--transition-interactive);
}
.conversation-card:hover {
  box-shadow: var(--shadow-md), var(--shadow-glow);
  border-color: rgba(26,154,181,0.3); transform: translateY(-1px);
}
.convo-top {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: var(--space-2); gap: var(--space-2);
}
.convo-contact {
  font-family: var(--font-display); font-size: var(--text-sm); font-weight: 700;
  color: var(--color-text);
}
.convo-client-tag {
  font-size: 10px; font-weight: 600; padding: 1px 7px; border-radius: var(--radius-full);
  background: var(--navy); color: rgba(255,255,255,0.85); font-family: var(--font-display);
  letter-spacing: 0.3px;
}
.convo-last-reply {
  font-size: var(--text-xs); color: var(--color-text-muted); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  font-family: var(--font-body);
}
.convo-meta {
  display: flex; gap: var(--space-3); margin-top: var(--space-2); font-size: 11px;
  color: var(--color-text-faint); font-family: var(--font-body); align-items: center;
}
.convo-unread {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 10px; font-weight: 700; color: var(--teal);
  background: var(--teal-subtle); padding: 2px 7px; border-radius: var(--radius-full);
}

/* ===== KPI REPORTS PAGE ===== */
#page-reports { padding: var(--space-5) var(--space-6); }
.reports-header { margin-bottom: var(--space-5); }
.reports-header-top {
  display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-4);
}
.reports-header h3 {
  font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700;
  color: var(--color-text); letter-spacing: -0.3px;
}
.report-subtitle {
  font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1);
  font-family: var(--font-body);
}
.report-export-btns {
  display: flex; gap: var(--space-2); flex-shrink: 0; align-items: center; padding-top: 4px;
}
.report-export-btns .btn { display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.report-export-btns .btn svg { flex-shrink: 0; }
.btn-outline {
  background: transparent; border: 1px solid var(--color-border);
  color: var(--color-text-muted); font-size: var(--text-sm); padding: 6px 14px;
  border-radius: var(--radius-md); cursor: pointer; transition: all 0.2s;
}
.btn-outline:hover { border-color: var(--color-accent); color: var(--color-accent); }
.btn-sm { font-size: var(--text-sm); padding: 6px 14px; }

/* KPI Grid — auto-fit for tier-dependent card count */
.kpi-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.kpi-card {
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-4); text-align: center;
  transition: all var(--transition-interactive); position: relative; overflow: hidden;
}
.kpi-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--teal); opacity: 0; transition: opacity var(--transition-interactive);
}
.kpi-card:hover::before { opacity: 1; }
.kpi-card:hover { box-shadow: var(--shadow-md), var(--shadow-glow); transform: translateY(-2px); }
.kpi-label {
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.5px;
  margin-bottom: var(--space-2);
}
.kpi-value {
  font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800;
  color: var(--color-text); letter-spacing: -0.5px; line-height: 1;
}
.kpi-delta {
  display: inline-flex; align-items: center; gap: 2px;
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 700;
  margin-top: var(--space-2); padding: 2px 8px; border-radius: var(--radius-full);
}
.kpi-delta.positive { background: var(--color-success-highlight); color: var(--color-success); }
.kpi-delta.negative { background: var(--color-error-highlight); color: var(--color-error); }
.kpi-delta.neutral { background: var(--color-surface-dynamic); color: var(--color-text-faint); }

/* Report sections */
.report-section {
  margin-bottom: var(--space-6);
}
.report-section-title {
  font-family: var(--font-display); font-size: var(--text-base); font-weight: 700;
  color: var(--color-text); letter-spacing: -0.2px; margin-bottom: var(--space-3);
}

/* Funnel */
.funnel-container {
  display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3);
  flex-wrap: wrap;
}
.funnel-stage {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-1);
  flex: 1; min-width: 80px;
}
.funnel-bar {
  width: 100%; height: 48px; border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 800;
  color: #fff; position: relative;
}
.funnel-stage-label {
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.4px;
}
.funnel-arrow {
  font-size: var(--text-lg); color: var(--color-text-faint); flex-shrink: 0; margin-top: -16px;
}
.funnel-conversions {
  display: flex; gap: var(--space-4); flex-wrap: wrap;
}
.funnel-conv-item {
  font-size: var(--text-xs); color: var(--color-text-muted); font-family: var(--font-body);
}
.funnel-conv-item strong {
  color: var(--teal); font-family: var(--font-display); font-weight: 700;
}

/* Channel grid */
.channel-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3);
}
.channel-card {
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-4); text-align: center;
}
.channel-label {
  font-family: var(--font-display); font-size: var(--text-sm); font-weight: 700;
  color: var(--color-text); margin-bottom: var(--space-2);
}
.channel-stat {
  font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 800;
  color: var(--teal); line-height: 1;
}
.channel-sublabel {
  font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-1);
  font-family: var(--font-body);
}
.channel-response {
  margin-top: var(--space-3); padding-top: var(--space-3);
  border-top: 1px solid var(--color-border-subtle);
}
.channel-response-label {
  font-size: var(--text-xs); color: var(--color-text-muted); font-family: var(--font-body);
}
.channel-response-value {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700;
  color: var(--color-text);
}

/* Report tables */
.report-table-wrap { overflow-x: auto; }
.report-table {
  width: 100%; border-collapse: collapse; font-family: var(--font-body);
  font-size: var(--text-sm);
}
.report-table th {
  font-family: var(--font-display); font-size: var(--text-xs); font-weight: 700;
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.5px;
  padding: var(--space-2) var(--space-3); text-align: left;
  border-bottom: 2px solid var(--teal); background: var(--color-surface);
  white-space: nowrap;
}
.report-table td {
  padding: var(--space-2) var(--space-3); color: var(--color-text);
  border-bottom: 1px solid var(--color-border-subtle); vertical-align: middle;
}
.report-table tr:hover td { background: var(--color-surface-dynamic); }
.report-table .risk-badge {
  display: inline-block; font-size: 10px; font-weight: 700; padding: 2px 8px;
  border-radius: var(--radius-full); background: var(--color-warning-highlight);
  color: var(--color-warning); text-transform: uppercase; letter-spacing: 0.3px;
}
.report-empty {
  font-size: var(--text-sm); color: var(--color-text-muted); font-family: var(--font-body);
  padding: var(--space-4); text-align: center; background: var(--color-surface);
  border-radius: var(--radius-lg); border: 1px solid var(--color-border-subtle);
}

/* Service Tier Badges */
.report-tier-badge { margin-top: var(--space-2); }
.tier-badge {
  display: inline-block; font-family: var(--font-display); font-size: var(--text-xs);
  font-weight: 700; padding: 3px 12px; border-radius: var(--radius-full);
  text-transform: uppercase; letter-spacing: 0.6px;
}
.tier-badge.tier-professional {
  background: rgba(26, 154, 181, 0.12); color: var(--teal); border: 1px solid rgba(26, 154, 181, 0.25);
}
.tier-badge.tier-enhanced {
  background: rgba(168, 130, 60, 0.12); color: #b8962e; border: 1px solid rgba(168, 130, 60, 0.25);
}
.tier-badge.tier-signature {
  background: rgba(130, 80, 200, 0.12); color: #9b6cd4; border: 1px solid rgba(130, 80, 200, 0.25);
}
/* Small tier badge for client cards */
.tier-badge-sm {
  display: inline-block; font-family: var(--font-display); font-size: 9px;
  font-weight: 700; padding: 1px 6px; border-radius: var(--radius-full);
  text-transform: uppercase; letter-spacing: 0.4px; vertical-align: middle; margin-left: 4px;
}
.tier-badge-sm.tier-professional { background: rgba(26, 154, 181, 0.12); color: var(--teal); }
.tier-badge-sm.tier-enhanced { background: rgba(168, 130, 60, 0.12); color: #b8962e; }
.tier-badge-sm.tier-signature { background: rgba(130, 80, 200, 0.12); color: #9b6cd4; }

/* KPI Category accents */
.kpi-cat-applications::before { background: var(--navy); }
.kpi-cat-direct::before { background: var(--teal); }
.kpi-cat-indirect::before { background: #b8962e; }
.kpi-cat-responses::before { background: var(--color-success); }
.kpi-cat-rate::before { background: #7c5cbf; }
.kpi-cat-interviews::before { background: #2DCAE6; }
.kpi-cat-applications:hover::before,
.kpi-cat-direct:hover::before,
.kpi-cat-indirect:hover::before,
.kpi-cat-responses:hover::before,
.kpi-cat-rate:hover::before,
.kpi-cat-interviews:hover::before { opacity: 1; }

/* KPI channel breakdown */
.kpi-breakdown {
  display: flex; gap: var(--space-2); justify-content: center;
  margin-top: var(--space-2); flex-wrap: wrap;
}
.kpi-channel-tag {
  display: inline-flex; align-items: center; gap: 3px;
  font-family: var(--font-body); font-size: 10px; color: var(--color-text-muted);
  background: var(--color-surface-dynamic); padding: 1px 6px; border-radius: var(--radius-full);
}
.kpi-channel-dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
}
.kpi-channel-dot.email { background: var(--teal); }
.kpi-channel-dot.linkedin { background: #0077b5; }

/* Channel data source indicator */
.channel-source {
  display: inline-block; font-size: 9px; font-weight: 600; padding: 1px 6px;
  border-radius: var(--radius-full); margin-left: 6px; text-transform: uppercase;
  letter-spacing: 0.3px; vertical-align: middle;
}
.channel-source.source-auto {
  background: rgba(26, 154, 181, 0.12); color: var(--teal);
}
.channel-source.source-manual {
  background: var(--color-surface-dynamic); color: var(--color-text-faint);
}

/* Networking Activity Summary */
.networking-summary-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-3);
}
.networking-card {
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-4);
  transition: all var(--transition-interactive);
}
.networking-card:hover {
  box-shadow: var(--shadow-md); transform: translateY(-1px);
}
.net-card-header { margin-bottom: var(--space-3); }
.net-card-title {
  font-family: var(--font-display); font-size: var(--text-sm); font-weight: 700;
  color: var(--color-text);
}
.net-card-desc {
  font-family: var(--font-body); font-size: var(--text-xs); color: var(--color-text-muted);
  margin-top: var(--space-1);
}
.net-card-stats {
  display: flex; gap: var(--space-4);
}
.net-stat { text-align: center; flex: 1; }
.net-stat-value {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 800;
  color: var(--teal); line-height: 1;
}
.net-stat-label {
  font-family: var(--font-body); font-size: var(--text-xs); color: var(--color-text-muted);
  margin-top: var(--space-1);
}

/* ===== HAS CONTACTS BADGE ===== */
.card-contacts-badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(245,166,35,0.12); color: #d4940a;
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.03em; padding: 2px 8px;
  border-radius: var(--radius-full); margin-top: 4px;
  line-height: 1.4;
}
.card-contacts-badge svg { stroke: #d4940a; flex-shrink: 0; }
.has-contacts-card {
  border-left: 3px solid #d4940a;
}

/* ===== HAS CONTACTS FORM TOGGLE ===== */
.has-contacts-toggle {
  margin-top: var(--space-2);
}
.checkbox-label {
  display: flex; align-items: center; gap: 8px; cursor: pointer;
  font-size: var(--text-sm); color: var(--color-text);
  font-family: var(--font-body);
}
.checkbox-label input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: var(--teal);
  cursor: pointer; flex-shrink: 0;
}
.checkbox-text { font-weight: 500; }
#job-contact-fields {
  background: rgba(245,166,35,0.05); border: 1px solid rgba(245,166,35,0.15);
  border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  margin-top: var(--space-2);
}
#job-contact-fields[hidden] { display: none; }

/* ===== VIEW AS CLIENT TOGGLE ===== */
.view-as-client-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--text-xs); font-weight: 600;
  color: var(--color-text-muted); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-full); padding: 4px 12px;
  transition: all var(--transition-interactive);
}
.view-as-client-btn:hover { color: var(--teal); border-color: var(--teal); }
.view-as-client-btn.view-active {
  background: var(--teal); color: #fff; border-color: var(--teal);
}
.view-as-client-btn.view-active svg { stroke: #fff; }
.client-preview-mode .top-bar {
  border-bottom: 2px solid var(--teal);
}
.client-preview-mode .top-bar::after {
  content: 'CLIENT PREVIEW'; position: absolute; right: var(--space-6); top: 50%;
  transform: translateY(-50%); font-size: 9px; font-weight: 800;
  letter-spacing: 0.1em; color: var(--teal); opacity: 0.6;
  pointer-events: none;
}

/* ===== MESSAGE INSTRUCTION BANNERS ===== */
.msg-instruction-banner {
  background: rgba(26,154,181,0.08); border: 1px solid rgba(26,154,181,0.2);
  border-radius: var(--radius-md); padding: 12px 16px; margin-bottom: var(--space-4);
  font-size: var(--text-sm); color: var(--color-text); line-height: 1.5;
  font-family: var(--font-body);
}
.msg-instruction-banner strong { color: var(--teal); }
.msg-instruction-banner.returned {
  background: rgba(245,166,35,0.08); border-color: rgba(245,166,35,0.25);
}
.msg-instruction-banner.returned strong { color: #d4940a; }
.msg-instruction-banner.approved {
  background: rgba(39,174,96,0.08); border-color: rgba(39,174,96,0.2);
}
.msg-instruction-banner.approved strong { color: #27ae60; }
.msg-instruction-banner.sent {
  background: rgba(39,174,96,0.06); border-color: rgba(39,174,96,0.15);
}
.msg-instruction-banner.sent strong { color: #1e8449; }

/* ===== ADMIN ATTENTION BANNER ===== */
.msg-attention-banner {
  background: rgba(231,76,60,0.06); border: 1px solid rgba(231,76,60,0.2);
  border-left: 3px solid #e74c3c; border-radius: var(--radius-md);
  padding: 12px 16px; margin-bottom: var(--space-4);
  font-size: var(--text-sm); color: var(--color-text); line-height: 1.5;
  font-family: var(--font-body);
}
.msg-attention-banner strong { color: #c0392b; }

/* ===== ATTENTION BADGE ON MESSAGE CARDS ===== */
.msg-attention-badge {
  display: inline-flex; align-items: center;
  background: rgba(231,76,60,0.12); color: #c0392b;
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.04em; padding: 2px 8px;
  border-radius: var(--radius-full); line-height: 1.4;
}
.attention-card {
  border-left: 3px solid #e74c3c;
}

/* ===== FEEDBACK REQUIRED STATE ===== */
.feedback-required {
  border-color: #e74c3c !important;
  box-shadow: 0 0 0 2px rgba(231,76,60,0.15);
  animation: feedbackPulse 0.6s ease-in-out;
}
@keyframes feedbackPulse {
  0%, 100% { box-shadow: 0 0 0 2px rgba(231,76,60,0.15); }
  50% { box-shadow: 0 0 0 4px rgba(231,76,60,0.25); }
}

/* ===== MESSAGE EDIT TEXTAREA ===== */
.msg-edit-body {
  width: 100%; padding: 12px; font-size: var(--text-sm);
  font-family: var(--font-body); color: var(--color-text);
  background: var(--color-bg); border: 1px solid var(--teal);
  border-radius: var(--radius-md); resize: vertical;
  line-height: 1.6; transition: border-color var(--transition-interactive);
}
.msg-edit-body:focus {
  outline: none; border-color: var(--teal);
  box-shadow: 0 0 0 2px rgba(26,154,181,0.15);
}

/* ===== MESSAGE EDITED BADGE ===== */
.msg-edited-badge {
  display: inline-block; margin-top: var(--space-2);
  font-size: var(--text-xs); color: var(--teal); font-weight: 600;
  font-family: var(--font-body);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 900px) {
  .sidebar { transform: translateX(-100%); transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1); }
  .sidebar.open { transform: translateX(0); }
  .mobile-menu-btn { display: flex; }
  .main-content { margin-left: 0; }
  .form-row { grid-template-columns: 1fr; }
  .stats-bar { flex-wrap: wrap; gap: var(--space-3); padding: var(--space-3) var(--space-4); }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .channel-grid { grid-template-columns: 1fr; }
  .networking-summary-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .top-bar { flex-wrap: wrap; padding: var(--space-2) var(--space-3); }
  .top-bar-left { padding-left: 44px; }
  .kanban-column { flex: 0 0 240px; }
  #page-jobs { padding: var(--space-3); }
  #page-messages { padding: var(--space-3); }
  #page-clients { padding: var(--space-3); }
  #page-reports { padding: var(--space-3); }
  .client-name { display: none; }
  .modal { margin: var(--space-2); }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .funnel-container { flex-direction: column; }
  .funnel-arrow { transform: rotate(90deg); }
}

/* ===== CHAT ===== */
.chat-container {
  display: flex; flex-direction: column;
  height: calc(100dvh - 160px); min-height: 400px;
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl); overflow: hidden;
}
.chat-messages-area {
  flex: 1; overflow-y: auto; padding: var(--space-6);
  display: flex; flex-direction: column;
  scroll-behavior: smooth;
}
.chat-empty {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-3); text-align: center; padding: var(--space-8);
}
.chat-empty p { color: var(--color-text-muted); font-size: var(--text-sm); margin: 0; max-width: 360px; line-height: 1.6; }
.chat-empty .chat-tip { font-size: var(--text-xs); color: var(--color-text-faint); }
.chat-thread { display: flex; flex-direction: column; gap: var(--space-3); }

/* Chat bubbles */
.chat-bubble {
  max-width: 72%; padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg); position: relative;
  font-size: var(--text-sm); line-height: 1.6;
  word-wrap: break-word; overflow-wrap: break-word;
}
.chat-bubble-outbound {
  align-self: flex-end;
  background: var(--teal);
  color: #ffffff;
  border-bottom-right-radius: var(--radius-sm);
}
.chat-bubble-inbound {
  align-self: flex-start;
  background: var(--color-surface-raised, rgba(255,255,255,0.06));
  border: 1px solid var(--color-border-subtle);
  color: var(--color-text);
  border-bottom-left-radius: var(--radius-sm);
}
.chat-bubble-sender {
  font-size: var(--text-xs); font-weight: 600;
  margin-bottom: 2px; opacity: 0.85;
  font-family: var(--font-display);
}
.chat-bubble-outbound .chat-bubble-sender { color: rgba(255,255,255,0.8); }
.chat-bubble-inbound .chat-bubble-sender { color: var(--teal); }
.chat-bubble-body { white-space: pre-wrap; }
.chat-bubble-time {
  font-size: 10px; margin-top: 4px;
  opacity: 0.6; text-align: right;
}

/* Link cards in chat */
.chat-link-card {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3); margin-top: var(--space-2);
  border-radius: var(--radius-md);
  text-decoration: none; transition: opacity 0.15s ease;
}
.chat-link-card:hover { opacity: 0.85; }
.chat-bubble-outbound .chat-link-card {
  background: rgba(255,255,255,0.15); color: #ffffff;
}
.chat-bubble-inbound .chat-link-card {
  background: rgba(26,154,181,0.08); color: var(--color-text);
  border: 1px solid var(--color-border-subtle);
}
.chat-link-icon {
  width: 32px; height: 32px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
}
.chat-bubble-outbound .chat-link-icon { background: rgba(255,255,255,0.2); }
.chat-bubble-inbound .chat-link-icon { background: rgba(26,154,181,0.12); color: var(--teal); }
.chat-link-info { flex: 1; min-width: 0; }
.chat-link-url {
  font-size: var(--text-xs); opacity: 0.7;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.chat-link-label {
  font-size: var(--text-sm); font-weight: 600;
  font-family: var(--font-display);
}

/* Date separator */
.chat-date-separator {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-2) 0; margin: var(--space-2) 0;
}
.chat-date-separator::before,
.chat-date-separator::after {
  content: ''; flex: 1; height: 1px;
  background: var(--color-border-subtle);
}
.chat-date-label {
  font-size: var(--text-xs); color: var(--color-text-faint);
  font-family: var(--font-display); font-weight: 500;
  white-space: nowrap;
}

/* Chat input */
.chat-input-area {
  padding: var(--space-4); border-top: 1px solid var(--color-border-subtle);
  background: var(--color-surface);
}
.chat-form {
  display: flex; align-items: flex-end; gap: var(--space-3);
}
.chat-input {
  flex: 1; resize: none; border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-3) var(--space-4);
  font-family: var(--font-body); font-size: var(--text-sm);
  background: var(--color-bg); color: var(--color-text);
  line-height: 1.5; max-height: 120px; min-height: 40px;
  transition: border-color 0.15s ease;
  outline: none;
}
.chat-input:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 2px rgba(26,154,181,0.15);
}
.chat-input::placeholder { color: var(--color-text-faint); }
.chat-send-btn {
  width: 40px; height: 40px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--teal); color: #ffffff;
  border: none; border-radius: var(--radius-lg);
  cursor: pointer; transition: background 0.15s ease, transform 0.1s ease;
}
.chat-send-btn:hover { background: var(--navy); }
.chat-send-btn:active { transform: scale(0.95); }
.chat-send-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Chat: no client selected state */
.chat-no-client {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: var(--space-3);
  color: var(--color-text-muted); font-size: var(--text-sm);
  text-align: center; padding: var(--space-8);
}

/* Typing indicator (optional future use) */
.chat-typing {
  font-size: var(--text-xs); color: var(--color-text-faint);
  padding: 0 var(--space-4); font-style: italic;
}

/* Mobile chat */
@media (max-width: 768px) {
  .chat-container { height: calc(100dvh - 120px); border-radius: 0; border: none; }
  .chat-bubble { max-width: 85%; }
}

/* ===== INTERVIEW HISTORY ===== */
.interviews-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-4); gap: var(--space-4); flex-wrap: wrap;
}
.interviews-header-left h3 {
  font-family: var(--font-heading); font-size: var(--text-lg);
  font-weight: 700; color: var(--color-text); margin: 0;
}
.interviews-subtitle {
  font-size: var(--text-sm); color: var(--color-text-muted); margin: var(--space-1) 0 0;
}
.interviews-filters {
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  margin-bottom: var(--space-5);
}
.interviews-list {
  display: flex; flex-direction: column; gap: var(--space-3);
}
.interviews-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-3); padding: var(--space-12) var(--space-4);
  color: var(--color-text-muted); font-size: var(--text-sm); text-align: center;
}

/* Interview Cards */
.interview-card {
  background: var(--color-surface); border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-5);
  cursor: pointer; transition: border-color 0.15s, box-shadow 0.15s;
}
.interview-card:hover {
  border-color: var(--color-accent, #1a9ab5);
  box-shadow: 0 2px 12px rgba(26,154,181,0.1);
}
.interview-card-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: var(--space-3); margin-bottom: var(--space-3);
}
.interview-card-left { flex: 1; min-width: 0; }
.interview-company {
  font-family: var(--font-heading); font-size: var(--text-base);
  font-weight: 700; color: var(--color-text); margin: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.interview-position {
  font-size: var(--text-sm); color: var(--color-text-secondary);
  margin: var(--space-1) 0 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Outcome Badges */
.outcome-badge {
  display: inline-flex; align-items: center; padding: 3px 10px;
  font-size: 11px; font-weight: 700; border-radius: 20px;
  text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap; flex-shrink: 0;
}
.outcome-pending {
  background: rgba(255,193,7,0.12); color: #f5a623;
}
.outcome-positive {
  background: rgba(76,175,80,0.12); color: #4caf50;
}
.outcome-neutral {
  background: rgba(158,158,158,0.12); color: #9e9e9e;
}
.outcome-negative {
  background: rgba(244,67,54,0.12); color: #f44336;
}
.outcome-offer {
  background: rgba(26,154,181,0.15); color: #1a9ab5;
}
.outcome-rejected {
  background: rgba(244,67,54,0.08); color: #e57373;
}

/* Card Meta Row */
.interview-card-meta {
  display: flex; flex-wrap: wrap; gap: var(--space-3);
  font-size: var(--text-xs); color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
.interview-meta-item {
  display: inline-flex; align-items: center; gap: 4px;
}
.interview-meta-item svg { flex-shrink: 0; opacity: 0.6; }
.interview-contact-title {
  opacity: 0.7; font-style: italic;
}

/* Feedback + Notes */
.interview-card-feedback {
  font-size: var(--text-sm); color: var(--color-text-secondary);
  line-height: 1.5; margin-top: var(--space-3); padding-top: var(--space-3);
  border-top: 1px solid var(--color-border-subtle);
}
.interview-card-feedback strong {
  color: var(--color-text); font-weight: 600;
}
.interview-card-notes {
  font-size: var(--text-xs); color: var(--color-text-muted);
  line-height: 1.5; margin-top: var(--space-2); font-style: italic;
}

/* Mobile */
@media (max-width: 768px) {
  .interviews-header { flex-direction: column; align-items: flex-start; }
  .interview-card-header { flex-direction: column; }
  .outcome-badge { align-self: flex-start; }
  .interview-card-meta { flex-direction: column; gap: var(--space-2); }
}

/* ===== QUEUE COLUMN ===== */
.kanban-column.queue-column .column-header {
  background: #2d2b55;
}
.queue-column .column-header h3 { margin-bottom: 0; }
.queue-subtitle {
  font-size: 10px; font-weight: 400; color: rgba(255,255,255,0.5);
  letter-spacing: 0.5px; text-transform: uppercase; display: block; margin-top: 2px;
}
.queue-source-tag {
  display: inline-block; font-size: 10px; color: rgba(255,255,255,0.5);
  background: rgba(45,43,85,0.3); border: 1px solid rgba(45,43,85,0.5);
  padding: 1px 6px; border-radius: var(--radius-sm); margin-top: 4px;
  font-family: var(--font-body);
}

/* ===== CYCLE BANNER ===== */
.cycle-banner {
  height: 40px; display: flex; align-items: center; justify-content: center; gap: var(--space-3);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  background: var(--color-surface); padding: 0 var(--space-4);
  font-size: var(--text-sm); color: var(--color-text-secondary); font-family: var(--font-body);
}
.cycle-banner[hidden] { display: none; }
.cycle-banner-text { white-space: nowrap; }
.cycle-progress {
  width: 120px; height: 4px; border-radius: 2px;
  background: rgba(255,255,255,0.1); overflow: hidden; flex-shrink: 0;
}
.cycle-progress-fill {
  height: 100%; border-radius: 2px;
  transition: width 0.5s ease, background-color 0.3s ease;
}

/* ===== EXPIRING ALERT ===== */
.expiring-alert {
  background: #f39c12; color: #1a1e2a; padding: 10px 20px;
  font-weight: 600; font-size: var(--text-sm); font-family: var(--font-display);
  display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap;
}
.expiring-alert[hidden] { display: none; }
.expiring-alert-item {
  display: inline-flex; align-items: center; gap: var(--space-2);
  margin-right: var(--space-4);
}
.expiring-alert-item .client-link {
  cursor: pointer; text-decoration: underline; font-weight: 700;
}
.expiring-alert-item .client-link:hover { opacity: 0.8; }
.expiring-alert-dismiss {
  margin-left: auto; background: none; border: none; cursor: pointer;
  color: #1a1e2a; font-size: 18px; line-height: 1; padding: 0 4px; opacity: 0.7;
}
.expiring-alert-dismiss:hover { opacity: 1; }

/* ===== SEARCH PROFILE BUTTON ===== */
.search-profile-btn svg { opacity: 0.7; }
.search-profile-btn:hover svg { opacity: 1; }

/* ===== CYCLE INFO IN CLIENT CARDS ===== */
.client-cycle-info {
  display: flex; align-items: center; gap: var(--space-2);
  margin-top: var(--space-2); font-size: var(--text-xs);
  font-family: var(--font-body);
}
.cycle-status-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.cycle-status-dot.green { background: #1A9AB5; }
.cycle-status-dot.orange { background: #e67e22; }
.cycle-status-dot.red { background: #e74c3c; }
.client-cycle-info .cycle-action-btn {
  font-size: 11px; padding: 2px 8px; margin-left: auto;
  border: 1px solid var(--color-border-subtle); border-radius: var(--radius-sm);
  background: transparent; color: var(--color-text-secondary); cursor: pointer;
  font-family: var(--font-body); transition: background 0.2s, color 0.2s;
}
.client-cycle-info .cycle-action-btn:hover {
  background: var(--teal, #1A9AB5); color: #fff; border-color: var(--teal, #1A9AB5);
}
.no-cycle-text { color: var(--color-text-muted); }

/* ===== QUEUE COUNT IN CLIENT CARDS ===== */
.client-card-queue {
  font-size: var(--text-xs); color: rgba(45,43,85,0.9); font-weight: 600;
  background: rgba(45,43,85,0.15); padding: 1px 6px; border-radius: var(--radius-sm);
  display: inline-flex; align-items: center; gap: 3px;
}

/* Fix hidden attribute on buttons with display: inline-flex */
.btn[hidden], .search-profile-btn[hidden] { display: none; }
.expiring-alert[hidden] { display: none; }
#cycle-banner[hidden] { display: none; }
