/* ============================================================
   MAYER OS v3 — COMMAND CENTRE
   Redesign: Obsidian Command aesthetic
   Unbounded + Hanken Grotesk + Martian Mono
   OKLCH color system. No side stripes. No hero metrics.
   ============================================================ */

/* ── DESIGN TOKENS ── */
:root {
  /* Base surfaces */
  --bg-base:    oklch(10% 0.007 255);
  --bg-raised:  oklch(13.5% 0.008 255);
  --bg-card:    oklch(16% 0.009 255);
  --bg-input:   oklch(8% 0.005 255 / 70%);
  --bg-overlay: oklch(6% 0.006 255 / 94%);

  /* Gold system */
  --gold:       oklch(73% 0.12 74);
  --gold-light: oklch(87% 0.07 79);
  --gold-dim:   oklch(73% 0.12 74 / 10%);
  --gold-glow:  oklch(73% 0.12 74 / 22%);

  /* Accent */
  --accent: oklch(52% 0.07 62);

  /* Text */
  --ivory:       oklch(97% 0.008 80);
  --ivory-muted: oklch(97% 0.008 80 / 82%);

  /* Muted */
  --muted:     oklch(54% 0.018 265);
  --muted-dim: oklch(34% 0.014 265);

  /* Status */
  --red:   oklch(60% 0.21 24);
  --amber: oklch(73% 0.13 65);
  --blue:  oklch(65% 0.15 250);
  --green: oklch(69% 0.11 152);

  /* Borders */
  --border:       oklch(73% 0.12 74 / 13%);
  --border-hover: oklch(73% 0.12 74 / 30%);
  --border-focus: oklch(73% 0.12 74 / 50%);

  /* Shadows */
  --shadow-sm:   0 1px 3px oklch(0% 0 0 / 50%);
  --shadow-md:   0 4px 16px oklch(0% 0 0 / 60%);
  --shadow-lg:   0 8px 32px oklch(0% 0 0 / 70%);
  --shadow-gold: 0 0 24px oklch(73% 0.12 74 / 12%);

  /* Typography */
  --font-display: 'Unbounded', sans-serif;
  --font-body:    'Hanken Grotesk', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:    'Martian Mono', 'Fira Code', monospace;

  /* Type scale — fixed for app UI */
  --text-xs:   0.75rem;    /* 12px */
  --text-sm:   0.8125rem;  /* 13px */
  --text-base: 0.875rem;   /* 14px */
  --text-md:   1rem;       /* 16px */
  --text-lg:   1.125rem;   /* 18px */
  --text-xl:   1.375rem;   /* 22px */
  --text-2xl:  1.75rem;    /* 28px */

  /* Transitions */
  --ease:      all 0.18s cubic-bezier(0.4, 0, 0.2, 1);
  --ease-slow: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);

  /* Layout */
  --topbar-h:     56px;
  --tabs-h:       44px;
  --mobile-nav-h: 64px;

  /* Spacing (4pt scale) */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-8: 32px; --sp-10: 40px;
  --sp-12: 48px;
}

/* ── RESET ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  background: var(--bg-base);
  color: var(--ivory);
  min-height: 100dvh;
  overflow-x: hidden;
  font-size: var(--text-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 3px; height: 3px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--muted-dim); border-radius: 8px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }
* { scrollbar-width: thin; scrollbar-color: var(--muted-dim) transparent; }

/* ── AMBIENT BACKGROUND ── */
.ambient-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden;
}
.grain-overlay {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity: 0.65;
}
.orb {
  position: absolute; border-radius: 50%;
  filter: blur(140px);
  animation: orbFloat 40s ease-in-out infinite alternate;
}
.orb-1 { width: 60vw; height: 60vw; background: oklch(73% 0.12 74); opacity: 0.03; top: -20%; left: -20%; }
.orb-2 { width: 50vw; height: 50vw; background: oklch(45% 0.08 260); opacity: 0.04; bottom: -25%; right: -20%; animation-delay: -15s; animation-duration: 55s; }
.orb-3 { width: 40vw; height: 40vw; background: oklch(52% 0.07 62); opacity: 0.025; top: 35%; left: 45%; animation-delay: -25s; animation-duration: 45s; }
@keyframes orbFloat {
  0%   { transform: translate(0, 0) scale(1); }
  100% { transform: translate(2%, 3%) scale(1.05); }
}

/* ── TYPOGRAPHY ── */
h1, h2, h3, h4 {
  font-family: var(--font-body);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.card-head {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.8px;
  color: var(--gold);
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--sp-3);
}

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.02em;
  border: none; border-radius: 6px;
  cursor: pointer; transition: var(--ease);
  white-space: nowrap; line-height: 1;
}
.btn-gold {
  background: var(--gold);
  color: oklch(10% 0.005 255);
  padding: 10px 20px;
  box-shadow: var(--shadow-sm), 0 0 0 1px oklch(73% 0.12 74 / 28%);
}
.btn-gold:hover {
  background: var(--gold-light);
  box-shadow: var(--shadow-md), var(--shadow-gold);
  transform: translateY(-1px);
}
.btn-gold:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
.btn-ghost {
  background: transparent;
  border: 1px solid var(--border-hover);
  color: var(--ivory-muted);
  padding: 9px 18px;
}
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.btn-sm { font-size: var(--text-xs); padding: 5px 12px; border-radius: 5px; }
.btn-full { width: 100%; }
.btn-row { display: flex; gap: var(--sp-2); margin-top: var(--sp-3); }

/* ── INPUTS ── */
.field { margin-bottom: var(--sp-4); text-align: left; }
.field label {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.6px;
  color: var(--gold);
  margin-bottom: var(--sp-1);
}
.input-el, .field input, .field textarea, .field select {
  width: 100%;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px 12px;
  color: var(--ivory);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  transition: var(--ease);
}
.input-el:focus, .field input:focus, .field textarea:focus, .field select:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px oklch(73% 0.12 74 / 6%);
}
.input-el::placeholder, .field input::placeholder,
.field textarea::placeholder { color: var(--muted); }
select {
  cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235A5A6E' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 28px;
}
input[type="color"] { height: 38px; padding: 3px; cursor: pointer; }
input[type="date"] { cursor: pointer; }
.form-message { margin-top: var(--sp-2); font-size: var(--text-xs); color: var(--red); }

/* ── LOGIN ── */
.login-screen {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 1000;
  background: var(--bg-overlay);
  backdrop-filter: blur(10px) saturate(120%);
}
.login-card {
  width: 400px; max-width: 92vw;
  padding: var(--sp-12) var(--sp-10);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-top: 1px solid var(--border-hover);
  border-radius: 12px;
  box-shadow: var(--shadow-lg);
  animation: fadeUp 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
  text-align: center;
  position: relative; z-index: 1;
}
.login-brand { margin-bottom: var(--sp-8); }
.login-monogram {
  display: block;
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-4);
}
.login-title {
  font-family: var(--font-display);
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--ivory-muted);
  letter-spacing: 5px;
  text-transform: uppercase;
}
.login-subtitle {
  font-size: var(--text-xs);
  font-weight: 400;
  letter-spacing: 3px;
  color: var(--muted);
  margin-top: var(--sp-1);
  text-transform: uppercase;
}
.login-actions {
  display: flex; justify-content: space-between;
  margin-top: var(--sp-4);
}
.login-actions a {
  font-size: var(--text-xs); color: var(--muted);
  text-decoration: none; transition: var(--ease);
}
.login-actions a:hover { color: var(--gold); }

/* ── MODALS ── */
.modal-overlay {
  position: fixed; inset: 0;
  background: var(--bg-overlay);
  backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000; padding: var(--sp-5);
}
.modal-box {
  width: 440px; max-width: 100%;
  max-height: 90vh; overflow-y: auto;
  padding: var(--sp-6) var(--sp-8);
  background: var(--bg-raised);
  border: 1px solid var(--border);
  border-top: 1px solid var(--border-hover);
  border-radius: 12px;
  box-shadow: var(--shadow-lg);
  animation: fadeUp 0.22s ease both;
  position: relative; z-index: 1;
}
.modal-wide { width: 560px; }
.modal-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border);
}
.modal-head h2 {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--ivory);
  margin: 0;
}
.modal-x {
  background: none; border: none; font-size: 18px;
  cursor: pointer; color: var(--muted);
  padding: 4px; line-height: 1; transition: var(--ease); border-radius: 4px;
}
.modal-x:hover { color: var(--red); background: oklch(60% 0.21 24 / 8%); }

.radio-row { display: flex; gap: var(--sp-4); margin-bottom: var(--sp-4); }
.radio-label {
  display: flex; align-items: center; gap: 6px;
  font-size: var(--text-sm); color: var(--ivory-muted); cursor: pointer;
}
.manage-list > div {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--sp-2) var(--sp-3); margin-bottom: 5px;
  background: oklch(8% 0.005 255 / 40%);
  border-radius: 8px; border: 1px solid var(--border);
}
.chip-row {
  display: flex; flex-wrap: wrap; gap: var(--sp-2);
  padding: var(--sp-2); border-radius: 8px;
  background: oklch(8% 0.005 255 / 30%); margin-top: 5px;
}
.chip-row label {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: var(--text-xs); cursor: pointer;
  background: oklch(8% 0.005 255 / 40%);
  padding: 5px 10px; border-radius: 20px; transition: var(--ease);
  text-transform: none; letter-spacing: 0; color: var(--ivory-muted);
  border: 1px solid transparent;
}
.chip-row label:hover { border-color: var(--border-hover); background: var(--gold-dim); }
.chip-row input[type="checkbox"] { width: 13px; height: 13px; accent-color: var(--gold); }
.settings-group { margin-bottom: var(--sp-5); display: flex; flex-direction: column; gap: 5px; }
.settings-label {
  font-size: var(--text-xs); text-transform: uppercase;
  letter-spacing: 1.6px; color: var(--muted); font-weight: 600;
}
.settings-group input {
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 6px; padding: 8px 11px;
  color: var(--ivory); font-size: var(--text-sm); font-family: var(--font-body);
}
.settings-group input:focus { outline: none; border-color: var(--border-focus); }

/* ── COMMAND BAR ── */
.command-overlay {
  position: fixed; inset: 0;
  background: oklch(0% 0 0 / 70%); backdrop-filter: blur(6px);
  z-index: 1100;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 18vh;
}
.command-box {
  width: 560px; max-width: 94vw;
  background: var(--bg-raised);
  border: 1px solid var(--border-hover);
  border-radius: 12px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  animation: fadeUp 0.18s ease both;
}
.command-box input {
  width: 100%; background: transparent; border: none;
  padding: 18px 22px;
  color: var(--ivory); font-size: var(--text-md); font-family: var(--font-body);
}
.command-box input:focus { outline: none; }
.command-box input::placeholder { color: var(--muted); }
.command-hints {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 22px 11px;
  font-size: var(--text-xs); color: var(--muted);
  border-top: 1px solid var(--border);
}
.kbd {
  display: inline-flex; align-items: center; padding: 2px 6px;
  background: oklch(100% 0 0 / 6%); border: 1px solid var(--border);
  border-radius: 4px; font-size: 10px; font-family: var(--font-mono); color: var(--muted);
}
.command-results { border-top: 1px solid var(--border); max-height: 300px; overflow-y: auto; }
.command-results:empty { display: none; }
.command-result-item {
  padding: 10px 22px; cursor: pointer; font-size: var(--text-sm);
  transition: var(--ease); border-bottom: 1px solid var(--border);
}
.command-result-item:hover { background: var(--gold-dim); }
.command-result-item .result-type {
  font-size: 10px; text-transform: uppercase; color: var(--muted); letter-spacing: 1.2px;
}

/* ── TOPBAR ── */
.topbar {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--topbar-h);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--sp-6);
  z-index: 100;
  background: oklch(9.5% 0.006 255 / 88%);
  backdrop-filter: blur(20px) saturate(150%);
  border-bottom: 1px solid var(--border);
}
.topbar-left { display: flex; align-items: center; }
.topbar-brand {
  font-family: var(--font-display);
  font-size: 0.625rem;
  font-weight: 700;
  color: var(--ivory);
  letter-spacing: 5px;
  user-select: none;
  text-transform: uppercase;
}
.brand-dot { color: var(--gold); }
.topbar-center { flex: 1; display: flex; justify-content: center; padding: 0 var(--sp-4); }
.command-trigger {
  display: flex; align-items: center; gap: 8px; padding: 7px 14px;
  background: oklch(100% 0 0 / 3%); border: 1px solid var(--border);
  border-radius: 8px; color: var(--muted); cursor: pointer; transition: var(--ease);
  font-family: var(--font-body); font-size: var(--text-sm);
}
.command-trigger:hover {
  border-color: var(--border-hover); color: var(--ivory-muted);
  background: oklch(100% 0 0 / 5%);
}
.topbar-right { display: flex; align-items: center; gap: var(--sp-2); }
.topbar-date {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--muted); letter-spacing: 0.03em;
}
/* User avatar — replaces exposed email */
.user-avatar {
  width: 28px; height: 28px;
  background: var(--gold-dim);
  border: 1px solid var(--border-hover);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; font-family: var(--font-mono);
  color: var(--gold); flex-shrink: 0; cursor: default;
}
.user-email { display: none; }
.top-btn {
  background: transparent; border: 1px solid var(--border);
  color: var(--muted); width: 32px; height: 32px;
  border-radius: 6px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--ease);
}
.top-btn:hover { border-color: var(--gold); color: var(--gold); box-shadow: var(--shadow-gold); }

/* ── PROJECT TABS ── */
.proj-tabs {
  position: fixed; top: var(--topbar-h); left: 0; right: 0;
  height: var(--tabs-h);
  display: flex; align-items: center; gap: 5px; padding: 0 var(--sp-6);
  background: oklch(9.5% 0.006 255 / 78%); backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border); overflow-x: auto; z-index: 90;
}
.proj-tabs::-webkit-scrollbar { height: 0; }
.proj-tab-wrap { position: relative; flex-shrink: 0; }
.proj-tab {
  background: transparent; border: 1px solid oklch(100% 0 0 / 4%);
  border-radius: 6px; padding: 5px 14px;
  font-size: var(--text-xs); font-weight: 500; font-family: var(--font-body);
  color: var(--muted); cursor: pointer; white-space: nowrap;
  transition: var(--ease); letter-spacing: 0.02em;
}
.proj-tab:hover { border-color: var(--border-hover); color: var(--ivory-muted); }
.proj-tab-wrap.active .proj-tab {
  background: var(--gold-dim);
  border-color: oklch(73% 0.12 74 / 28%);
  color: var(--gold-light);
}
.proj-dot {
  display: inline-block; width: 5px; height: 5px;
  border-radius: 50%; margin-right: 5px; vertical-align: middle; margin-bottom: 1px;
}
.proj-add-btn {
  background: transparent; border: 1px dashed var(--border-hover);
  border-radius: 6px; padding: 5px 12px;
  font-size: var(--text-xs); color: var(--muted);
  cursor: pointer; white-space: nowrap; transition: var(--ease);
  font-family: var(--font-body);
}
.proj-add-btn:hover { border-color: var(--gold); color: var(--gold); }
.proj-tab-badge {
  position: absolute; top: -4px; right: -4px;
  background: var(--red); color: oklch(97% 0 0);
  font-size: 9px; font-weight: 700; min-width: 15px; height: 15px;
  border-radius: 20px; display: flex; align-items: center; justify-content: center;
  padding: 0 3px; font-family: var(--font-mono); pointer-events: none;
  box-shadow: 0 0 0 2px var(--bg-base);
}
.proj-tab-wrap[draggable="true"] { cursor: grab; user-select: none; }
.proj-tab-wrap[draggable="true"]:active { cursor: grabbing; }

/* ── APP GRID ── */
.app-grid {
  display: grid;
  grid-template-columns: 272px 1fr 352px;
  gap: 0;
  margin-top: calc(var(--topbar-h) + var(--tabs-h));
  height: calc(100vh - var(--topbar-h) - var(--tabs-h));
  height: calc(100dvh - var(--topbar-h) - var(--tabs-h));
  overflow: hidden; position: relative; z-index: 10;
}
.col { overflow-y: auto; padding: var(--sp-4) var(--sp-3); }
.col:not(:last-child) { border-right: 1px solid var(--border); }
.col-inner { display: flex; flex-direction: column; gap: var(--sp-4); }

/* ── CARDS ── */
.card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; padding: var(--sp-4); transition: var(--ease);
}
.card:hover { border-color: var(--border-hover); }

/* ── STATS BAR (replaces hero metric grid) ── */
.stats-bar {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px;
}
.stat-chip {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: var(--sp-3) var(--sp-2);
  text-align: center; transition: var(--ease);
  border-top-width: 2px;
}
.stat-chip:hover { border-color: var(--border-hover); transform: translateY(-1px); }
.stat-num {
  font-family: var(--font-mono);
  font-size: 1.4rem; font-weight: 600;
  display: block; line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.stat-lbl {
  font-size: 9px; text-transform: uppercase;
  letter-spacing: 1.4px; color: var(--muted);
  margin-top: 3px; display: block;
}
.stat-chip.overdue  { border-top-color: var(--red); }
.stat-chip.pending  { border-top-color: var(--amber); }
.stat-chip.progress { border-top-color: var(--blue); }
.stat-chip.done     { border-top-color: var(--green); }
.stat-chip.overdue .stat-num  { color: var(--red); }
.stat-chip.pending .stat-num  { color: var(--amber); }
.stat-chip.progress .stat-num { color: var(--blue); }
.stat-chip.done .stat-num     { color: var(--green); }

/* ── TEAM WORKLOAD ── */
.workload-list { display: flex; flex-direction: column; gap: 2px; }
.workload-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 0; border-bottom: 1px solid var(--border);
  font-size: var(--text-sm);
}
.workload-item:last-child { border-bottom: none; }
.workload-name { font-weight: 600; color: var(--ivory); }
.workload-stats { display: flex; gap: var(--sp-3); font-size: var(--text-xs); }
.workload-pending   { color: var(--amber); }
.workload-completed { color: var(--green); }

/* ── TEAM SIDEBAR ── */
.team-sidebar-list { max-height: 220px; overflow-y: auto; }
.member-item {
  display: flex; gap: var(--sp-2); align-items: center;
  padding: 7px var(--sp-2); border-radius: 8px; margin-bottom: 3px; transition: var(--ease);
}
.member-item:hover { background: oklch(0% 0 0 / 20%); }
.member-avatar {
  width: 28px; height: 28px;
  background: var(--gold-dim);
  border: 1px solid var(--border-hover);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; font-family: var(--font-mono);
  color: var(--gold); flex-shrink: 0;
}
.member-details { flex: 1; min-width: 0; }
.member-name { font-weight: 600; font-size: var(--text-sm); }
.member-role { font-size: var(--text-xs); color: var(--muted); margin-top: 1px; }
.member-actions { display: flex; gap: 3px; }
.edit-member-btn, .del-member {
  background: none; border: none; font-size: var(--text-xs); cursor: pointer;
  color: var(--muted); padding: 4px; border-radius: 4px; transition: var(--ease);
}
.edit-member-btn:hover { color: var(--gold); }
.del-member:hover { color: var(--red); }

/* ── TASK BOARD ── */
.card-tasks { flex: 1; display: flex; flex-direction: column; }

/* Two-row add task form */
.add-task-row { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.add-task-primary { display: flex; gap: var(--sp-2); }
.add-task-details {
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: var(--sp-2);
}
.task-desc { flex: 1; resize: vertical; min-height: 38px; max-height: 100px; }

.filter-row { display: flex; gap: 5px; margin-bottom: var(--sp-3); flex-wrap: wrap; }
.filter-chip {
  background: transparent; border: 1px solid oklch(100% 0 0 / 5%);
  border-radius: 6px; padding: 4px 12px;
  font-size: var(--text-xs); font-family: var(--font-body); font-weight: 500;
  cursor: pointer; color: var(--muted); transition: var(--ease); letter-spacing: 0.02em;
}
.filter-chip.active {
  background: var(--gold-dim);
  border-color: oklch(73% 0.12 74 / 22%);
  color: var(--gold-light);
}
.filter-chip:hover { border-color: var(--border-hover); color: var(--ivory-muted); }

.task-list { flex: 1; overflow-y: auto; padding-right: 3px; }
.empty-state {
  text-align: center; padding: var(--sp-10) var(--sp-5);
  color: var(--muted); font-size: var(--text-sm); letter-spacing: 0.02em;
}

/* ── TASK CARDS ── */
.task-card {
  background: oklch(13% 0.007 255 / 80%);
  border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: 8px; padding: var(--sp-3);
  margin-bottom: 5px;
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--sp-3); transition: var(--ease);
}
.task-card:hover { border-color: var(--border-hover); background: oklch(16% 0.009 255 / 90%); transform: translateX(2px); }
.task-card.overdue    { border-left-color: var(--red); background: oklch(60% 0.21 24 / 6%); }
.task-card.in-progress { border-left-color: var(--blue); }
.task-card.pending    { border-left-color: var(--amber); }
.task-card.done       { border-left-color: var(--green); opacity: 0.55; }

.task-info { flex: 1; min-width: 0; }
.task-name { font-weight: 600; font-size: var(--text-sm); margin-bottom: 4px; color: var(--ivory); }
.task-meta {
  display: flex; gap: var(--sp-2); flex-wrap: wrap;
  font-size: var(--text-xs); color: var(--muted); align-items: center;
}

/* Status badge (replaces side stripe) */
.task-status-badge {
  display: inline-flex; align-items: center;
  padding: 2px 7px; border-radius: 20px;
  font-size: 9px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.8px;
  flex-shrink: 0;
}
.task-status-badge.overdue    { background: oklch(60% 0.21 24 / 15%); color: var(--red); }
.task-status-badge.pending    { background: oklch(73% 0.13 65 / 12%); color: var(--amber); }
.task-status-badge.in-progress { background: oklch(65% 0.15 250 / 12%); color: var(--blue); }
.task-status-badge.done       { background: oklch(69% 0.11 152 / 12%); color: var(--green); }

.task-priority { font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
.task-priority.high   { color: var(--red); }
.task-priority.medium { color: var(--amber); }
.task-priority.low    { color: var(--green); }

.task-actions { display: flex; gap: 5px; align-items: center; flex-shrink: 0; }
.status-select {
  background: oklch(8% 0.005 255 / 50%); border: 1px solid var(--border);
  border-radius: 5px; padding: 4px 7px;
  color: var(--ivory-muted); font-size: var(--text-xs); cursor: pointer;
  font-family: var(--font-body);
}
.action-btn {
  background: oklch(8% 0.005 255 / 40%); border: 1px solid var(--border);
  border-radius: 5px; width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--muted); transition: var(--ease);
}
.action-btn:hover { border-color: var(--border-hover); color: var(--ivory); }
.action-btn.danger:hover { border-color: var(--red); color: var(--red); background: oklch(60% 0.21 24 / 8%); }
.action-btn.chase:hover  { border-color: var(--gold); color: var(--gold); }

.deadline-wrapper { display: inline-flex; align-items: center; gap: 3px; }
.edit-deadline-btn {
  background: none; border: none; font-size: 10px;
  cursor: pointer; color: var(--muted); padding: 1px 2px;
  border-radius: 3px; transition: var(--ease);
}
.edit-deadline-btn:hover { color: var(--gold); }

/* ── INTELLIGENCE COLUMN — chat dominates ── */
.col-intel {
  display: flex; flex-direction: column; overflow: hidden;
  padding: var(--sp-4) var(--sp-3);
}
.col-intel .col-inner {
  flex: 1; min-height: 0; overflow: hidden;
  display: flex; flex-direction: column; gap: var(--sp-4);
}
.card-chat {
  flex: 1; display: flex; flex-direction: column;
  min-height: 200px; overflow: hidden;
}
.chat-messages {
  flex: 1; overflow-y: auto; min-height: 0;
  padding-right: 3px;
}

.scroll-list { max-height: 140px; overflow-y: auto; }
.master-scroll { max-height: 120px; }
.notes-scroll  { max-height: 110px; }

.master-entry, .note-item {
  background: oklch(8% 0.005 255 / 40%); border-radius: 6px;
  padding: var(--sp-2) var(--sp-3); margin-bottom: 5px;
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: var(--sp-2); border: 1px solid var(--border);
}
.master-content, .note-content {
  font-size: var(--text-xs); flex: 1; line-height: 1.5; color: var(--ivory-muted);
}
.master-meta, .note-meta {
  font-size: 10px; color: var(--muted); margin-top: 3px; font-family: var(--font-mono);
}
.delete-master-btn, .delete-note-btn {
  background: none; border: none; color: var(--muted);
  cursor: pointer; font-size: 12px; padding: 2px 3px;
  transition: var(--ease); flex-shrink: 0;
}
.delete-master-btn:hover, .delete-note-btn:hover { color: var(--red); }

.chat-message { margin-bottom: var(--sp-2); }
.chat-message.user .chat-bubble {
  background: var(--gold-dim);
  border: 1px solid oklch(73% 0.12 74 / 18%);
  border-radius: 10px 10px 3px 10px;
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--text-sm); margin-left: var(--sp-8); line-height: 1.5;
}
.chat-message.assistant .chat-bubble {
  background: oklch(8% 0.005 255 / 50%);
  border: 1px solid var(--border);
  border-radius: 10px 10px 10px 3px;
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--text-sm); margin-right: var(--sp-8); line-height: 1.5;
}
.chat-time {
  font-size: 10px; color: var(--muted); margin-top: 3px; font-family: var(--font-mono);
}
.chat-message.user .chat-time { text-align: right; }

.chat-input-row { display: flex; gap: var(--sp-2); align-items: flex-end; margin-top: var(--sp-2); }
.chat-input-row textarea {
  flex: 1; background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 8px; padding: var(--sp-2) var(--sp-3);
  color: var(--ivory); font-size: var(--text-sm); font-family: var(--font-body);
  resize: none; min-height: 44px; max-height: 100px; line-height: 1.5;
}
.chat-input-row textarea:focus { outline: none; border-color: var(--border-focus); }
.chat-input-row .btn { flex-shrink: 0; }
.notes-input-row { display: flex; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.notes-input-row .input-el { flex: 1; }
.notes-input-row .btn { flex-shrink: 0; }

/* ── DROPDOWNS ── */
.dropdown-wrap { position: relative; }
.icon-btn {
  background: transparent; border: none; color: var(--muted);
  cursor: pointer; padding: 4px; border-radius: 4px;
  transition: var(--ease); display: flex; align-items: center;
}
.icon-btn:hover { color: var(--gold); }
.dropdown-menu {
  position: absolute; top: 100%; right: 0;
  background: var(--bg-raised); border: 1px solid var(--border-hover);
  border-radius: 8px; padding: 5px 0; min-width: 150px;
  z-index: 100; display: none; flex-direction: column;
  box-shadow: var(--shadow-lg);
}
.dropdown-menu.show { display: flex; }
.dropdown-item {
  background: transparent; border: none; padding: 7px 14px; text-align: left;
  color: var(--ivory-muted); font-size: var(--text-xs); font-family: var(--font-body);
  cursor: pointer; transition: var(--ease);
}
.dropdown-item:hover { background: var(--gold-dim); color: var(--gold-light); }

/* ── TOAST — top border, no side stripe ── */
.toast-wrap {
  position: fixed; bottom: var(--sp-6); right: var(--sp-6);
  z-index: 1100; display: flex; flex-direction: column;
  gap: var(--sp-2); pointer-events: none;
}
.toast {
  pointer-events: auto;
  background: var(--bg-raised);
  border: 1px solid var(--border-hover);
  border-top: 2px solid var(--gold);
  border-radius: 8px;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-sm); color: var(--ivory-muted);
  box-shadow: var(--shadow-md);
  animation: slideIn 0.22s cubic-bezier(0.34, 1.56, 0.64, 1);
  min-width: 200px; max-width: 300px;
}
.toast.error { border-top-color: var(--red); }

/* ── MOBILE NAV ── */
.mobile-nav {
  display: none; position: fixed; bottom: 0; left: 0; right: 0;
  height: var(--mobile-nav-h);
  background: oklch(9.5% 0.006 255 / 96%); backdrop-filter: blur(20px);
  border-top: 1px solid var(--border);
  justify-content: space-around; align-items: center;
  z-index: 200; padding-bottom: env(safe-area-inset-bottom, 0);
}
.mob-nav-btn {
  background: transparent; border: none; color: var(--muted);
  font-size: var(--text-xs); font-family: var(--font-body); font-weight: 500;
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 8px var(--sp-4); cursor: pointer; transition: var(--ease);
  letter-spacing: 0.04em; text-transform: uppercase;
}
.mob-nav-btn.active { color: var(--gold); }
.mob-nav-btn svg { stroke: currentColor; }

/* ── MOBILE MENU ── */
.mobile-menu-wrap { position: relative; }
.mobile-dropdown {
  position: absolute; top: 40px; right: 0;
  background: var(--bg-raised); border: 1px solid var(--border-hover);
  border-radius: 10px; padding: 5px 0; min-width: 170px;
  display: none; flex-direction: column; z-index: 200; box-shadow: var(--shadow-lg);
}
.mobile-dropdown.show { display: flex; }
.mobile-menu-item {
  background: transparent; border: none; padding: 11px var(--sp-4); text-align: left;
  color: var(--ivory-muted); font-size: var(--text-sm); font-family: var(--font-body);
  cursor: pointer; transition: var(--ease);
}
.mobile-menu-item:hover { background: var(--gold-dim); color: var(--gold-light); }
.mobile-menu-item.danger { color: var(--red); }
.mobile-menu-item.danger:hover { background: oklch(60% 0.21 24 / 8%); }

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes slideIn {
  from { opacity: 0; transform: translateX(16px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ── VISIBILITY HELPERS ── */
.mobile-only  { display: none; }
.desktop-only { display: inline-flex; }

/* ════════════════════════════════════════════ */
/* RESPONSIVE                                  */
/* ════════════════════════════════════════════ */

@media (max-width: 1200px) {
  .app-grid { grid-template-columns: 240px 1fr 320px; }
}

@media (max-width: 1024px) {
  .desktop-only { display: none; }
  .mobile-only  { display: flex; }
  .mobile-nav   { display: flex; }
  .topbar { padding: 0 var(--sp-4); }
  .topbar-brand { font-size: 0.5rem; }
  .topbar-date { display: none; }
  .command-trigger .command-label { display: none; }
  .command-trigger .kbd { display: none; }
  .proj-tabs { padding: 0 var(--sp-4); }
  .app-grid {
    grid-template-columns: 1fr;
    height: calc(100dvh - var(--topbar-h) - var(--tabs-h) - var(--mobile-nav-h));
    overflow: hidden;
  }
  .col:not(:last-child) { border-right: none; }
  .col { display: none; padding: var(--sp-4); }
  .col.active-mobile { display: block; overflow-y: auto; height: 100%; }
  .col-intel.active-mobile { display: flex; flex-direction: column; }
  .task-card { flex-direction: column; align-items: stretch; gap: var(--sp-2); }
  .task-actions { justify-content: flex-end; }
  .action-btn, .status-select { min-height: 40px; min-width: 40px; }
  .add-task-details { grid-template-columns: 1fr 1fr; }
  .add-task-meta { grid-template-columns: 1fr 1fr; }
  .chat-input-row { flex-direction: column; }
  .chat-input-row .btn { width: 100%; }
  .toast-wrap { bottom: calc(var(--mobile-nav-h) + var(--sp-3)); right: var(--sp-4); left: var(--sp-4); }
  .stats-bar { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .topbar { height: 48px; }
  :root { --topbar-h: 48px; --tabs-h: 40px; }
  .topbar-brand { font-size: 0.4375rem; letter-spacing: 3px; }
  .login-card { padding: var(--sp-8) var(--sp-6); }
  .modal-box { padding: var(--sp-5); }
  .command-box input { font-size: var(--text-md); padding: var(--sp-4) var(--sp-5); }
  .add-task-details { grid-template-columns: 1fr; }
  .add-task-meta { grid-template-columns: 1fr 1fr; }
  .stats-bar { grid-template-columns: repeat(2, 1fr); }
}

/* ════════════════════════════════════════════════════════════
   MISSING CLASS DEFINITIONS (HTML v3 restructure)
   ════════════════════════════════════════════════════════════ */

/* ── COLUMN TYPE OVERRIDES ── */
.col-tasks {
  display: flex; flex-direction: column; overflow: hidden; padding: 0;
}
/* col-dashboard uses standard .col styles — no override needed */

/* ── PROJECT INFO BAR ── */
.proj-info-bar {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.proj-info-left { flex: 1; min-width: 0; }
.proj-info-right { flex-shrink: 0; display: flex; align-items: center; }
.proj-info-name {
  font-size: var(--text-md); font-weight: 700;
  font-family: var(--font-display);
  color: var(--gold); letter-spacing: 0.02em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.proj-info-role {
  font-size: var(--text-xs); color: var(--muted);
  margin-top: 2px; letter-spacing: 0.04em; text-transform: uppercase;
}
.proj-info-desc {
  font-size: var(--text-xs); color: var(--ivory-muted); margin-top: 2px;
}

/* ── TASK PANEL BODY ── */
.task-panel-body {
  flex: 1; display: flex; flex-direction: column;
  overflow: hidden; padding: var(--sp-3) var(--sp-4);
  min-height: 0;
}

/* ── ADD TASK (renamed classes) ── */
.add-task-wrap {
  display: flex; flex-direction: column; gap: var(--sp-2);
  margin-bottom: var(--sp-3); flex-shrink: 0;
}
.task-desc-input {
  flex: 1; resize: vertical; min-height: 38px; max-height: 100px;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 6px; padding: 10px 12px; color: var(--ivory);
  font-size: var(--text-sm); font-family: var(--font-body);
  transition: var(--ease); line-height: 1.5;
}
.task-desc-input:focus {
  outline: none; border-color: var(--border-focus);
  box-shadow: 0 0 0 3px oklch(73% 0.12 74 / 6%);
}
.task-desc-input::placeholder { color: var(--muted); }
.btn-add-task {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--gold); color: oklch(10% 0.005 255);
  font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600;
  letter-spacing: 0.02em; border: none; border-radius: 6px;
  padding: 10px 20px; cursor: pointer; transition: var(--ease);
  white-space: nowrap; flex-shrink: 0;
  box-shadow: var(--shadow-sm), 0 0 0 1px oklch(73% 0.12 74 / 28%);
}
.btn-add-task:hover {
  background: var(--gold-light);
  box-shadow: var(--shadow-md), var(--shadow-gold);
  transform: translateY(-1px);
}
.add-task-meta {
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: var(--sp-2);
}

/* ── SORT SELECT ── */
.sort-select {
  background: oklch(8% 0.005 255 / 50%); border: 1px solid var(--border);
  border-radius: 6px; padding: 4px 10px;
  color: var(--ivory-muted); font-size: var(--text-xs); cursor: pointer;
  font-family: var(--font-body); margin-left: auto; flex-shrink: 0;
  transition: var(--ease);
}
.sort-select:focus { outline: none; border-color: var(--border-focus); }
.sort-select:hover { border-color: var(--border-hover); }

/* ── INTELLIGENCE PANEL — tab system ── */
.col-intel { padding: 0; }

.intel-header {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3) 0;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.intel-brand {
  font-size: var(--text-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: 2.5px;
  color: var(--gold); font-family: var(--font-mono);
  white-space: nowrap; padding-bottom: var(--sp-2);
}
.intel-tabs { display: flex; gap: 0; flex: 1; }
.itab {
  background: transparent; border: none;
  border-bottom: 2px solid transparent;
  padding: var(--sp-2) var(--sp-3) calc(var(--sp-2) - 2px);
  font-size: var(--text-xs); font-weight: 600;
  color: var(--muted); cursor: pointer; transition: var(--ease);
  font-family: var(--font-body); letter-spacing: 0.04em;
  position: relative; display: inline-flex; align-items: center;
  gap: 5px; white-space: nowrap;
}
.itab:hover { color: var(--ivory-muted); }
.itab.active { color: var(--gold); border-bottom-color: var(--gold); }
.itab-badge {
  background: var(--red); color: oklch(97% 0 0);
  font-size: 9px; font-weight: 700; border-radius: 20px;
  min-width: 14px; height: 14px; padding: 0 3px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
}
.intel-actions { display: flex; align-items: center; margin-left: auto; padding-bottom: var(--sp-1); }

.itab-panel {
  display: none; flex: 1; flex-direction: column;
  overflow: hidden; min-height: 0;
}
.itab-panel.active { display: flex; }

/* ── CHAT TAB INNER LAYOUT ── */
.empty-chat {
  text-align: center; padding: var(--sp-10) var(--sp-5);
  color: var(--muted); font-size: var(--text-sm);
  letter-spacing: 0.02em; flex: 1;
}
.chat-input-area {
  border-top: 1px solid var(--border);
  padding: var(--sp-3);
  flex-shrink: 0;
}
.chat-secondary-row {
  display: flex; gap: var(--sp-2); margin-top: var(--sp-2);
}
.chat-secondary-row .btn { flex: 1; }

/* ── NOTES TAB INNER LAYOUT ── */
.notes-panel {
  display: flex; flex-direction: column;
  flex: 1; overflow: hidden; padding: var(--sp-3);
  gap: var(--sp-2);
}
.notes-list {
  flex: 1; overflow-y: auto; padding-right: 2px;
}
.notes-footer { flex-shrink: 0; padding-top: var(--sp-1); }

/* ── LOG TAB INNER LAYOUT ── */
.log-panel {
  display: flex; flex-direction: column;
  flex: 1; overflow: hidden; padding: var(--sp-3);
  gap: var(--sp-2);
}
.log-list {
  flex: 1; overflow-y: auto; padding-right: 2px;
}
.log-footer {
  display: flex; gap: var(--sp-2);
  flex-shrink: 0; padding-top: var(--sp-1);
}

/* ════════════════════════════════════════════════════
   NEW FEATURES — Global Dashboard, Person Tasks,
   Bulk Add, Priority Filter, Better Members
   ════════════════════════════════════════════════════ */

/* ── PRIORITY FILTER ── */
.priority-filter-wrap {
  display: flex; align-items: center; gap: 5px; flex-wrap: wrap;
}
.priority-chip {
  background: transparent; border: 1px solid oklch(100% 0 0 / 5%);
  border-radius: 6px; padding: 4px 10px;
  font-size: var(--text-xs); font-family: var(--font-body); font-weight: 600;
  cursor: pointer; transition: var(--ease); letter-spacing: 0.02em;
}
.priority-chip:hover { border-color: var(--border-hover); }
.priority-chip.active-high   { background: oklch(60% 0.21 24 / 14%); border-color: oklch(60% 0.21 24 / 35%); color: var(--red); }
.priority-chip.active-medium { background: oklch(73% 0.13 65 / 12%); border-color: oklch(73% 0.13 65 / 32%); color: var(--amber); }
.priority-chip.active-low    { background: oklch(69% 0.11 152 / 12%); border-color: oklch(69% 0.11 152 / 32%); color: var(--green); }
.priority-chip-high   { color: var(--red); }
.priority-chip-medium { color: var(--amber); }
.priority-chip-low    { color: var(--green); }
.filter-divider {
  width: 1px; height: 16px; background: var(--border);
  flex-shrink: 0; margin: 0 2px;
}

/* ── GLOBAL DASHBOARD TOGGLE ── */
.dash-scope-row {
  display: flex; gap: 5px; margin-bottom: var(--sp-3); align-items: center;
}
.dash-scope-btn {
  background: transparent; border: 1px solid var(--border);
  border-radius: 6px; padding: 4px 12px;
  font-size: var(--text-xs); font-weight: 600; font-family: var(--font-body);
  cursor: pointer; color: var(--muted); transition: var(--ease);
}
.dash-scope-btn.active {
  background: var(--gold-dim); border-color: oklch(73% 0.12 74 / 28%);
  color: var(--gold-light);
}
.dash-scope-btn:hover { border-color: var(--border-hover); color: var(--ivory-muted); }
.project-filter-select {
  background: oklch(8% 0.005 255 / 50%); border: 1px solid var(--border);
  border-radius: 6px; padding: 4px 24px 4px 10px;
  color: var(--ivory-muted); font-size: var(--text-xs); cursor: pointer;
  font-family: var(--font-body); margin-left: auto;
  transition: var(--ease); appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235A5A6E' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 7px center;
}
.project-filter-select:focus { outline: none; border-color: var(--border-focus); }

/* Global task list in dashboard */
.global-task-list { display: flex; flex-direction: column; gap: 4px; }
.global-task-item {
  background: oklch(13% 0.007 255 / 80%); border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: 7px; padding: 8px var(--sp-3);
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--sp-2); transition: var(--ease); cursor: pointer;
  font-size: var(--text-xs);
}
.global-task-item:hover { border-color: var(--border-hover); background: oklch(16% 0.009 255 / 90%); }
.global-task-item.overdue    { border-left-color: var(--red); }
.global-task-item.in-progress { border-left-color: var(--blue); }
.global-task-item.pending    { border-left-color: var(--amber); }
.global-task-item.done       { border-left-color: var(--green); opacity: 0.55; }
.global-task-name { font-weight: 600; color: var(--ivory); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.global-task-meta { display: flex; gap: 6px; align-items: center; flex-shrink: 0; }
.global-proj-badge {
  font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 2px 6px; border-radius: 4px;
  background: oklch(73% 0.12 74 / 10%); color: var(--gold);
}
.global-assignee { color: var(--muted); font-size: 10px; }

/* ── IMPROVED GLOBAL MEMBERS CARDS ── */
.member-global-card {
  background: oklch(13% 0.007 255 / 80%);
  border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px;
  margin-bottom: 8px; transition: var(--ease);
}
.member-global-card:hover { border-color: var(--border-hover); }
.member-global-top {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: var(--sp-3);
}
.member-global-left { display: flex; gap: var(--sp-3); align-items: flex-start; flex: 1; min-width: 0; }
.member-global-avatar {
  width: 38px; height: 38px; flex-shrink: 0;
  background: var(--gold-dim); border: 1px solid var(--border-hover);
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 700; font-family: var(--font-mono);
  color: var(--gold);
}
.member-global-info { flex: 1; min-width: 0; }
.member-global-name {
  font-weight: 700; font-size: var(--text-sm); color: var(--ivory);
  cursor: pointer; transition: var(--ease);
}
.member-global-name:hover { color: var(--gold); }
.member-global-role { font-size: var(--text-xs); color: var(--muted); margin-top: 2px; }
.member-global-phone { font-size: var(--text-xs); color: var(--muted); margin-top: 1px; font-family: var(--font-mono); }
.member-global-actions { display: flex; gap: 5px; flex-shrink: 0; }
.member-global-bottom { margin-top: 10px; display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.member-proj-chip {
  font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 20px;
  background: oklch(73% 0.12 74 / 10%); color: var(--gold);
  border: 1px solid oklch(73% 0.12 74 / 20%);
}
.member-wa-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 20px;
  background: oklch(52% 0.2 162 / 12%); color: oklch(70% 0.18 162);
  border: 1px solid oklch(52% 0.2 162 / 25%);
  text-decoration: none; transition: var(--ease);
}
.member-wa-badge:hover { background: oklch(52% 0.2 162 / 20%); }

/* ── PERSON TASKS MODAL ── */
.modal-ultra-wide { width: 680px; }
.person-tasks-header {
  display: flex; align-items: center; gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.person-tasks-avatar {
  width: 42px; height: 42px; flex-shrink: 0;
  background: var(--gold-dim); border: 1px solid var(--border-hover);
  border-radius: 10px; display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 700; font-family: var(--font-mono);
  color: var(--gold);
}
.person-tasks-name { font-size: var(--text-lg); font-weight: 700; color: var(--ivory); }
.person-tasks-meta { font-size: var(--text-xs); color: var(--muted); margin-top: 2px; }
.person-tasks-filters {
  display: flex; gap: 5px; margin-bottom: var(--sp-3); flex-wrap: wrap;
}
.person-task-card {
  background: oklch(13% 0.007 255 / 80%); border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: 8px; padding: 10px var(--sp-3);
  margin-bottom: 5px; display: flex; flex-direction: column; gap: 4px;
  transition: var(--ease);
}
.person-task-card.overdue    { border-left-color: var(--red); }
.person-task-card.in-progress { border-left-color: var(--blue); }
.person-task-card.pending    { border-left-color: var(--amber); }
.person-task-card.done       { border-left-color: var(--green); opacity: 0.55; }
.person-task-title { font-weight: 600; font-size: var(--text-sm); color: var(--ivory); }
.person-task-info { display: flex; gap: 8px; align-items: center; font-size: var(--text-xs); }

/* ── BULK ADD MODAL ── */
.bulk-task-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: var(--sp-2); margin-bottom: var(--sp-3);
  padding: var(--sp-3); background: oklch(8% 0.005 255 / 30%);
  border-radius: 8px; border: 1px solid var(--border);
}
.bulk-task-fields {
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: var(--sp-2); margin-top: var(--sp-2);
}
.bulk-task-remove {
  background: none; border: none; color: var(--muted);
  cursor: pointer; padding: 4px 6px; border-radius: 4px;
  transition: var(--ease); align-self: center; font-size: 16px;
}
.bulk-task-remove:hover { color: var(--red); }
.bulk-add-actions {
  display: flex; gap: var(--sp-2); margin-top: var(--sp-3);
}

/* ── WORKLOAD BAR ── */
.workload-bar-wrap {
  flex: 1; height: 4px; background: var(--border);
  border-radius: 2px; overflow: hidden; margin: 0 8px;
}
.workload-bar-fill {
  height: 100%; border-radius: 2px;
  background: linear-gradient(90deg, var(--gold), var(--amber));
  transition: width 0.5s ease;
}

/* ── CARD ENHANCEMENTS ── */
.card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; padding: var(--sp-4); transition: var(--ease);
  border-top: 1px solid oklch(73% 0.12 74 / 10%);
}
.card:hover { border-color: var(--border-hover); }

/* Topbar gradient accent */
.topbar {
  background: linear-gradient(
    90deg,
    oklch(9.5% 0.006 255 / 92%) 0%,
    oklch(10.5% 0.008 255 / 90%) 50%,
    oklch(9.5% 0.006 255 / 92%) 100%
  );
  border-bottom: 1px solid oklch(73% 0.12 74 / 18%);
}

/* Member WA link */
.member-wa-link {
  color: oklch(68% 0.18 162); transition: var(--ease);
  display: flex; align-items: center;
}
.member-wa-link:hover { color: oklch(75% 0.2 162); }

/* Deadline display inline */
.deadline-display { display: inline-flex; align-items: center; }
.deadline-text { cursor: pointer; transition: var(--ease); }
.deadline-text:hover { color: var(--gold); }
.deadline-text.due-soon { color: var(--amber); }
.deadline-text.overdue-date { color: var(--red); }
.deadline-input-inline {
  display: none; width: 120px;
  background: var(--bg-input); border: 1px solid var(--border-focus);
  border-radius: 4px; padding: 2px 6px;
  color: var(--ivory); font-size: var(--text-xs); font-family: var(--font-body);
}

/* Task assignee */
.task-assignee { color: var(--ivory-muted); font-weight: 500; }

/* Sort select & filter row improvements */
.filter-row { gap: 4px; align-items: center; }
.filter-chip { font-size: 11px; }

/* ── RESPONSIVE FIXES ── */
@media (max-width: 1024px) {
  .bulk-task-fields { grid-template-columns: 1fr 1fr; }
  .modal-ultra-wide { width: 100%; }
}
@media (max-width: 480px) {
  .bulk-task-fields { grid-template-columns: 1fr; }
}
