    * { margin: 0; padding: 0; box-sizing: border-box; }

    :root {
      /* Brand — Light theme matching website */
      --gold: #e2bd23;
      --gold-light: rgba(226, 189, 35, 0.1);
      --dark: #1a1a2e;
      --text: #1a1a2e;
      --text-light: #4a5568;
      --text-muted: #4a5568;
      --text-dim: #718096;
      --bg: #f7fafc;
      --white: #ffffff;
      --border: #e2e8f0;
      --border-light: #cbd5e0;
      --accent-hover: #c9a81e;
      --accent-glow: rgba(226, 189, 35, 0.35);
      --dusk: #4a6fa5;
      --dusk-light: rgba(74, 111, 165, 0.1);
      --success: #6ba73b;
      --warning: #f59e0b;
      --danger: #ef4444;
      /* Layout */
      --sidebar-w: 240px;
      /* Spacing scale (consistent 8px base) */
      --sp-xs: 4px;
      --sp-sm: 8px;
      --sp-md: 12px;
      --sp-lg: 16px;
      --sp-xl: 24px;
      --sp-2xl: 32px;
      --sp-3xl: 48px;
      /* Radius — rounder, more modern */
      --radius-sm: 6px;
      --radius-md: 10px;
      --radius-lg: 14px;
      --radius-xl: 18px;
      /* Animation */
      --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
      --duration-fast: 150ms;
      --duration-normal: 200ms;
      /* Shadows (3-tier, light theme) */
      --shadow-card: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
      --shadow-elevated: 0 4px 12px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
      --shadow-float: 0 8px 24px rgba(0,0,0,0.12), 0 4px 8px rgba(0,0,0,0.06);
      /* Surface layers (light) */
      --surface-0: #ffffff;
      --surface-1: #ffffff;
      --surface-2: #f7fafc;
      --surface-3: #edf2f7;
    }

    /* Global accessibility + polish */
    *, *::before, *::after { box-sizing: border-box; }
    button, [onclick], a, select, input[type="checkbox"], label.agent-skill-toggle { cursor: pointer; }
    button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
      outline: 2px solid var(--gold);
      outline-offset: 2px;
    }
    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
    }

    body {
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      background: var(--bg);
      color: var(--text);
      font-size: 14px;
      font-weight: 400;
      height: 100vh;
      display: flex;
      overflow: hidden;
      letter-spacing: -0.01em;
    }

    /* ── Sidebar ──────────────────────────────── */

    .sidebar {
      width: var(--sidebar-w);
      background: var(--white);
      color: var(--text);
      display: flex;
      flex-direction: column;
      flex-shrink: 0;
      border-right: 1px solid var(--border);
    }

    .sidebar-brand {
      padding: 20px 20px; display: flex; align-items: center; gap: 12px;
      border-bottom: 1px solid var(--border);
    }

    .sidebar-brand img {
      width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
    }

    .sidebar-brand h1 {
      font-size: 15px;
      font-weight: 800;
      color: var(--text);
      letter-spacing: -0.02em;
      line-height: 1.2;
    }

    .sidebar-nav { flex: 1; padding: 8px 8px; overflow-y: auto; }

    .nav-section-label {
      padding: 16px 12px 6px 12px;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 1.2px;
      color: var(--text-dim);
      text-transform: uppercase;
    }
    .nav-section-label:first-child { padding-top: 8px; }

    .nav-item {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 12px;
      cursor: pointer;
      color: var(--text-dim);
      font-size: 13px;
      font-weight: 500;
      transition: all 0.2s var(--ease-out);
      border-left: 3px solid transparent;
      border-radius: var(--radius-md);
      margin-bottom: 2px;
    }

    .nav-item:hover { color: var(--text); background: var(--surface-2); }

    .nav-item.active {
      color: var(--gold);
      background: var(--gold-light);
      border-left-color: transparent;
    }

    .nav-item svg { width: 18px; height: 18px; flex-shrink: 0; }

    .nav-badge {
      margin-left: auto;
      background: var(--gold);
      color: #020617;
      font-size: 11px;
      font-weight: 700;
      padding: 2px 7px;
      border-radius: 10px;
      min-width: 18px;
      text-align: center;
    }

    /* ── Main ─────────────────────────────────── */

    .main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

    .topbar {
      background: var(--white);
      border-bottom: 1px solid var(--border);
      padding: 14px 28px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-shrink: 0;
    }

    .topbar h2 { font-size: 18px; font-weight: 700; color: var(--text); }

    .content { flex: 1; overflow-y: auto; padding: 24px 28px; background: var(--bg); }

    /* ── Buttons ──────────────────────────────── */

    .btn {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 8px 16px; border-radius: var(--radius-md); border: none;
      font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 600;
      cursor: pointer; transition: all 0.2s var(--ease-out);
    }

    .btn-primary { background: var(--gold); color: #1a1a2e; }
    .btn-primary:hover { background: var(--accent-hover); box-shadow: 0 0 20px var(--accent-glow); }
    .btn-ghost { background: transparent; color: var(--text-light); border: 1px solid var(--border-light); }
    .btn-ghost:hover { background: var(--surface-2); color: var(--text); }
    .btn-sm { padding: 5px 10px; font-size: 12px; }
    .btn-danger { background: var(--danger); color: #fff; }
    .btn-danger:hover { background: #dc2626; }

    /* ── Cards ────────────────────────────────── */

    .card {
      background: var(--surface-1);
      border-radius: var(--radius-lg);
      border: 1px solid var(--border);
      box-shadow: var(--shadow-card);
      overflow: hidden;
      transition: transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out);
    }

    .card-hover:hover {
      transform: translateY(-2px);
      box-shadow: var(--shadow-elevated);
      border-color: rgba(226, 189, 35, 0.2);
    }

    .card-header {
      padding: 14px 18px;
      border-bottom: 1px solid var(--border);
      font-size: 12px; font-weight: 700;
      color: var(--text-dim);
      text-transform: uppercase;
      letter-spacing: 0.8px;
    }

    .list-item {
      display: flex; align-items: center; gap: 12px;
      padding: 12px 16px;
      border-bottom: 1px solid var(--border);
      cursor: pointer; transition: background 0.1s;
    }

    .list-item:last-child { border-bottom: none; }
    .list-item:hover { background: var(--bg); }

    .list-item .avatar {
      width: 36px; height: 36px; border-radius: 50%;
      background: var(--gold-light); color: var(--text);
      display: flex; align-items: center; justify-content: center;
      font-weight: 700; font-size: 14px; flex-shrink: 0;
    }

    .list-item .info { flex: 1; min-width: 0; }
    .list-item .name { font-weight: 600; font-size: 14px; color: var(--text); display: flex; align-items: center; gap: 4px; flex-wrap: wrap; }
    .list-item .preview { font-size: 13px; color: var(--text-light); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .list-item .meta { text-align: right; flex-shrink: 0; }
    .list-item .time { font-size: 11px; color: var(--text-light); }

    /* ── Badges ───────────────────────────────── */

    .badge { display: inline-block; padding: 2px 8px; border-radius: 9999px; font-size: 11px; font-weight: 600; }
    .badge-stage { background: rgba(226,189,35,0.1); color: #92400e; }
    .badge-handler { font-size: 10px; padding: 1px 6px; }
    .badge-ai { background: rgba(226,189,35,0.1); color: #92400e; }
    .badge-team { background: rgba(245,158,11,0.1); color: #92400e; }
    .badge-tag { background: var(--surface-2); color: var(--text-dim); font-size: 10px; padding: 1px 6px; margin-left: 2px; }
    .badge-tag-member { background: rgba(226,189,35,0.1); color: #92400e; }
    .badge-tag-ex-member { background: rgba(245,158,11,0.1); color: #92400e; }
    .badge-tag-retarget { background: rgba(139,92,246,0.1); color: #6d28d9; }
    .badge-tag-fb-lead { background: var(--dusk-light); color: #3a5a8a; }
    .badge-tag-coach { background: rgba(239,68,68,0.12); color: #f87171; }
    .badge-tag-newsletter { background: rgba(6,182,212,0.1); color: #0e7490; }

    /* ── Contact Filters ─────────────────────── */
    .contact-filters { display: flex; gap: 8px; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--border); flex-wrap: wrap; }
    .contact-filters input[type="text"] { flex: 1; min-width: 180px; padding: 7px 12px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .contact-filters input[type="text"]:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }
    .contact-filters select { padding: 7px 10px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; background: var(--white); cursor: pointer; outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .contact-filters select:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }
    .contact-count { font-size: 12px; color: var(--text-light); font-weight: 600; white-space: nowrap; }
    .contact-tags { display: flex; flex-wrap: wrap; gap: 2px; margin-top: 2px; }

    /* ── Contacts Table Layout ───────────────── */
    .contacts-layout { display: flex; height: calc(100% + 40px); margin: -20px -24px; }
    .contacts-table-wrap { flex: 1; overflow-y: auto; }
    .contacts-table { width: 100%; border-collapse: collapse; font-size: 13px; }
    .contacts-table thead th { position: sticky; top: 0; background: var(--bg); padding: 10px 12px; text-align: left; font-size: 11px; font-weight: 600; color: var(--text-light); text-transform: uppercase; letter-spacing: 0.5px; border-bottom: 2px solid var(--border); cursor: pointer; white-space: nowrap; user-select: none; }
    .contacts-table thead th:hover { color: var(--text); }
    .contacts-table tbody td { padding: 10px 12px; border-bottom: 1px solid var(--border); color: var(--text); vertical-align: middle; }
    .contacts-table tbody tr:nth-child(even) { background: rgba(247,250,252,0.5); }
    .contacts-table tbody tr:hover { background: var(--surface-2); }
    .contacts-table tbody tr.selected { background: var(--gold-light); border-left: 3px solid var(--gold); }
    .contact-detail-panel { width: 380px; flex-shrink: 0; border-left: 1px solid var(--border); background: var(--surface-1); display: flex; flex-direction: column; overflow: hidden; }
    .column-selector { position: relative; display: inline-block; }
    .column-selector-dropdown { position: absolute; right: 0; top: 100%; background: var(--surface-2); border: 1px solid var(--border-light); border-radius: var(--radius-md); box-shadow: var(--shadow-float); padding: 8px 0; z-index: 100; min-width: 180px; display: none; }
    .column-selector-dropdown.open { display: block; }
    .column-selector-dropdown label { display: flex; align-items: center; gap: 8px; padding: 6px 14px; font-size: 13px; cursor: pointer; }
    .column-selector-dropdown label:hover { background: var(--bg); }

    /* ── Contact Card ────────────────────────── */
    .contact-card-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.3); z-index: 1000; display: flex; align-items: center; justify-content: center; }
    .contact-card { background: var(--white); border-radius: var(--radius-lg); width: 900px; max-width: 95vw; max-height: 90vh; display: flex; flex-direction: column; box-shadow: 0 8px 30px rgba(0,0,0,0.15); }
    .merge-panel { background: var(--white); border-radius: 12px; width: 700px; max-width: 95vw; max-height: 85vh; display: flex; flex-direction: column; box-shadow: 0 8px 30px rgba(0,0,0,0.15); }
    .merge-candidate { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--border); gap: 12px; }
    .merge-candidate:last-child { border-bottom: none; }
    .contact-card-header { padding: 16px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
    .contact-card-header h3 { margin: 0; font-size: 18px; }
    .contact-card-body { display: flex; flex: 1; overflow: hidden; min-height: 0; }
    .contact-card-left { width: 320px; border-right: 1px solid var(--border); overflow-y: auto; padding: 16px; flex-shrink: 0; }
    .contact-card-right { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
    @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
    .spin { animation: spin 1s linear infinite; }
    .contact-card-tabs { display: flex; border-bottom: 1px solid var(--border); flex-shrink: 0; }
    .contact-card-tab { flex: 1; padding: 10px; text-align: center; font-size: 13px; font-weight: 600; cursor: pointer; border-bottom: 2px solid transparent; color: var(--text-light); }
    .contact-card-tab.active { color: var(--text); border-bottom-color: var(--gold); }
    .contact-card-tab:hover { background: var(--bg); }
    .contact-card-content { flex: 1; overflow-y: auto; padding: 16px; }
    .cc-field { margin-bottom: 12px; }
    .cc-field-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-light); margin-bottom: 2px; }
    .cc-field-value { font-size: 14px; color: var(--text); }
    .cc-section { margin-bottom: 16px; }
    .cc-section-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-light); margin-bottom: 8px; padding-bottom: 4px; border-bottom: 1px solid var(--border); }
    .cc-form-answer { padding: 8px 0; border-bottom: 1px solid var(--border); }
    .cc-form-q { font-size: 12px; color: var(--text-light); }
    .cc-form-a { font-size: 14px; color: var(--text); font-weight: 500; margin-top: 2px; }
    .cc-channel-badge { display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;gap:4px;cursor:default;transition:all 0.2s; }
    .cc-channel-badge:hover { transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,0.08); }
    .cc-quick-action { display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 10px;border-radius:6px;cursor:pointer;font-weight:600;font-family:'Barlow',sans-serif;transition:all 0.2s; }
    .cc-quick-action:hover { transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,0.1); }
    .cc-timeline { padding:0; }
    .cc-timeline-item { display:flex;gap:10px;padding:10px 0;border-bottom:1px solid #f0f0f0;transition:background 0.15s; }
    .cc-timeline-item:hover { background:var(--bg); }
    .cc-timeline-item:last-child { border-bottom:none; }
    .cc-timeline-dot { width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
    .cc-timeline-content { flex:1;min-width:0; }
    .badge-priority-urgent { background: rgba(239,68,68,0.1); color: #b91c1c; }
    .badge-priority-high { background: rgba(249,115,22,0.1); color: #c2410c; }
    .badge-priority-normal { background: rgba(226,189,35,0.1); color: #92400e; }
    .badge-priority-low { background: var(--surface-2); color: var(--text-dim); }

    /* ── Conversations ────────────────────────── */

    .conversation-split { display: flex; height: 100%; margin: -20px -24px; }

    .conv-list {
      width: 340px; border-right: 1px solid var(--border);
      overflow-y: auto; flex-shrink: 0; background: var(--surface-0);
      display: flex; flex-direction: column;
    }

    .conv-search { padding: 8px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
    .conv-search input { width: 100%; padding: 7px 12px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; font-family: 'Inter', sans-serif; outline: none; box-sizing: border-box; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .conv-search input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    .conv-filter {
      display: flex; gap: 4px; padding: 6px 12px;
      border-bottom: 1px solid var(--border); flex-shrink: 0;
    }

    .conv-filter-btn {
      flex: 1; padding: 5px 8px; border-radius: 6px; border: 1px solid var(--border);
      font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 600;
      cursor: pointer; background: var(--white); color: var(--text-light);
      transition: all 0.15s; text-align: center;
    }

    .conv-filter-btn:hover { background: var(--bg); }
    .conv-filter-btn.active { background: var(--gold); color: var(--text); border-color: var(--gold); }

    .conv-items { flex: 1; overflow-y: auto; }

    .conv-detail { flex: 1; display: flex; flex-direction: column; background: var(--bg); }

    .conv-detail-header {
      padding: 12px 16px; background: var(--white);
      border-bottom: 1px solid var(--border);
      display: flex; align-items: center; justify-content: space-between;
    }

    .conv-messages {
      flex: 1; overflow-y: auto; padding: 16px;
      display: flex; flex-direction: column; gap: 8px;
    }

    .msg { max-width: 70%; padding: 10px 14px; border-radius: 12px; font-size: 14px; line-height: 1.4; }
    .msg-inbound { background: var(--white); border: 1px solid var(--border); align-self: flex-start; border-bottom-left-radius: 4px; }
    .msg-outbound { background: var(--gold-light); align-self: flex-end; border-bottom-right-radius: 4px; }
    .msg-time { font-size: 10px; color: var(--text-light); margin-top: 4px; }
    .msg-sender { font-size: 10px; font-weight: 600; color: var(--text-light); margin-bottom: 2px; text-transform: uppercase; }
    .msg-feedback { margin-left: 8px; }
    .fb-btn { background: none; border: none; cursor: pointer; font-size: 14px; padding: 0 2px; transition: all 0.15s; filter: grayscale(1) brightness(0.7); }
    .fb-btn:hover { filter: grayscale(0) brightness(1); }
    .fb-btn.fb-active { filter: grayscale(0) brightness(1); }

    .conv-input {
      padding: 12px 16px; background: var(--white);
      border-top: 1px solid var(--border); display: flex; gap: 8px;
    }

    .conv-input input, .conv-input textarea {
      flex: 1; padding: 10px 14px; border: 1px solid var(--border);
      border-radius: 8px; font-family: 'Inter', sans-serif; font-size: 14px; outline: none;
      transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
    }

    .conv-input input:focus, .conv-input textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    .conv-empty {
      flex: 1; display: flex; align-items: center; justify-content: center;
      color: var(--text-light); font-size: 14px;
    }

    /* ── Pipeline board ───────────────────────── */

    .pipeline-board { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 12px; }
    .pipeline-col-header {
      font-size: 12px; font-weight: 600; text-transform: uppercase;
      letter-spacing: 0.5px; color: var(--text-light); padding: 8px 10px;
      display: flex; align-items: center; gap: 6px;
      background: var(--bg); border-radius: 6px; margin-bottom: 8px;
    }

    .pipeline-col-header .count {
      background: var(--border); color: var(--text);
      font-size: 11px; padding: 0 6px; border-radius: 8px;
    }

    .pipeline-col { min-width: 200px; flex: 1; min-height: 60px; padding-bottom: 8px; }

    .pipeline-card {
      background: var(--white); border: 1px solid var(--border);
      border-radius: var(--radius-md); padding: 10px 12px; margin-bottom: 8px;
      cursor: grab; transition: box-shadow 0.2s var(--ease-out), border-color 0.2s var(--ease-out), opacity 0.15s, transform 0.2s var(--ease-out);
      position: relative; box-shadow: var(--shadow-card);
    }

    .pipeline-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-elevated); }
    .pipeline-card:active { cursor: grabbing; transform: none; }
    .pipeline-card.dragging { opacity: 0.5; border-color: var(--gold); }

    .pipeline-col.drag-over {
      background: rgba(226,189,35,0.08);
      border-radius: 8px;
      outline: 2px dashed var(--gold);
      outline-offset: -2px;
    }

    .pipeline-card .card-top { display: flex; align-items: center; justify-content: space-between; }
    .pipeline-card .name { font-weight: 600; font-size: 14px; }
    .pipeline-card .phone { font-size: 12px; color: var(--text-light); }

    .pipeline-card .card-actions {
      display: flex; gap: 4px; margin-top: 6px; flex-wrap: wrap;
    }

    .pipeline-card .card-action-btn {
      padding: 3px 8px; border: 1px solid var(--border); border-radius: 4px;
      background: var(--bg); cursor: pointer; font-family: 'Inter', sans-serif;
      font-size: 11px; font-weight: 600; color: var(--text-light); transition: all 0.15s;
    }

    .pipeline-card .card-action-btn:hover { border-color: var(--gold); color: var(--text); background: var(--gold-light); }
    .pipeline-card .card-action-btn.action-success { border-color: var(--success); color: var(--success); }
    .pipeline-card .card-action-btn.action-success:hover { background: #dcfce7; color: #166534; }
    .pipeline-card .card-action-btn.action-warn { border-color: var(--warning); color: var(--warning); }
    .pipeline-card .card-action-btn.action-warn:hover { background: #fef3c7; color: #92400e; }
    .pipeline-card .card-action-btn.action-danger { border-color: var(--danger); color: var(--danger); }
    .pipeline-card .card-action-btn.action-danger:hover { background: #fee2e2; color: #b91c1c; }

    .pipeline-card .card-source { font-size: 11px; color: var(--text-light); margin-top: 2px; }
    .pipeline-card .card-handler { font-size: 10px; font-weight: 600; margin-top: 3px; }
    .pipeline-card .card-handler.chat-managed { color: #16a34a; }
    .pipeline-card .card-handler.team-action { color: #d97706; }

    /* Stage colour accents on pipeline cards */
    .pipeline-col[data-stage="lead"] .pipeline-card { border-left: 3px solid var(--success); }
    .pipeline-col[data-stage="booked"] .pipeline-card { border-left: 3px solid var(--gold); }
    .pipeline-col[data-stage="follow_up"] .pipeline-card { border-left: 3px solid var(--gold); }
    .pipeline-col[data-stage="no_show"] .pipeline-card { border-left: 3px solid var(--warning); }
    .pipeline-col[data-stage="closed"] .pipeline-card { border-left: 3px solid #94a3b8; opacity: 0.8; }

    /* Stage header colour dots */
    .stage-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
    .stage-dot.chat { background: var(--success); }
    .stage-dot.team { background: var(--gold); }
    .stage-dot.blue { background: var(--gold); }
    .stage-dot.warn { background: var(--warning); }
    .stage-dot.end { background: #94a3b8; }

    /* Outcome badges on closed cards */
    .card-handler.outcome-won { color: #16a34a; font-weight: 700; }
    .card-handler.outcome-ni { color: #94a3b8; }
    .card-handler.outcome-lost { color: #dc2626; }

    .move-dropdown {
      position: absolute; top: 100%; right: 0; z-index: 60;
      background: var(--white); border: 1px solid var(--border); border-radius: 8px;
      box-shadow: 0 8px 24px rgba(0,0,0,0.12); padding: 4px 0; min-width: 160px;
    }

    .move-dropdown.hidden { display: none; }

    .move-dropdown .move-option {
      display: block; width: 100%; text-align: left; padding: 7px 14px;
      font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500;
      border: none; background: none; cursor: pointer; color: var(--text);
      transition: background 0.1s;
    }

    .move-dropdown .move-option:hover { background: var(--bg); }
    .move-dropdown .move-option.current { color: var(--gold); font-weight: 700; cursor: default; }

    /* ── Card Message Popover ──────────────────── */

    .msg-popover {
      position: fixed; z-index: 200; width: 300px;
      background: var(--white); border: 1px solid var(--border); border-radius: 10px;
      box-shadow: 0 8px 28px rgba(0,0,0,0.14); animation: aiSlideIn 0.15s ease;
      font-family: 'Inter', sans-serif;
    }
    .msg-popover.hidden { display: none; }

    .msg-popover-header {
      display: flex; align-items: center; justify-content: space-between;
      padding: 10px 12px 6px; border-bottom: 1px solid var(--border);
    }
    .msg-popover-header .msg-name { font-size: 13px; font-weight: 600; color: var(--text); }
    .msg-popover-header .msg-close {
      background: none; border: none; cursor: pointer; color: var(--text-light);
      font-size: 16px; line-height: 1; padding: 0 2px;
    }
    .msg-popover-header .msg-close:hover { color: var(--text); }

    .msg-history {
      height: 120px; overflow-y: auto; padding: 8px 12px;
      border-bottom: 1px solid var(--border); scroll-behavior: smooth;
    }
    .msg-history::-webkit-scrollbar { width: 4px; }
    .msg-history::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

    .msg-bubble {
      font-size: 12px; line-height: 1.4; padding: 5px 9px; border-radius: 8px;
      margin-bottom: 4px; max-width: 85%; word-wrap: break-word;
    }
    .msg-bubble.inbound { background: var(--bg); color: var(--text); margin-right: auto; }
    .msg-bubble.outbound { background: var(--gold-light); color: var(--text); margin-left: auto; text-align: right; }
    .msg-bubble .msg-time { font-size: 10px; color: var(--text-light); margin-top: 1px; }
    .msg-bubble .msg-sender { font-size: 10px; font-weight: 600; color: var(--text-light); margin-bottom: 1px; }

    .msg-empty { padding: 20px 12px; text-align: center; color: var(--text-light); font-size: 12px; }

    .msg-compose {
      padding: 8px 10px; display: flex; gap: 6px; align-items: center;
    }
    .msg-compose input {
      flex: 1; padding: 7px 10px; border: 1px solid var(--border); border-radius: 6px;
      font-family: 'Inter', sans-serif; font-size: 12px; outline: none; background: var(--bg);
      transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out), background 0.2s var(--ease-out);
    }
    .msg-compose input:focus { border-color: var(--gold); background: var(--white); box-shadow: 0 0 0 3px var(--accent-glow); }
    .msg-compose .msg-send-btn {
      padding: 6px 10px; border: none; border-radius: 6px; cursor: pointer;
      background: var(--gold); color: var(--text); font-family: 'Inter', sans-serif;
      font-size: 11px; font-weight: 600; transition: opacity 0.15s;
    }
    .msg-compose .msg-send-btn:hover { opacity: 0.85; }

    .msg-channels {
      display: flex; gap: 6px; padding: 0 12px 8px; align-items: center;
    }
    .msg-channel-icon {
      width: 18px; height: 18px; border-radius: 4px; display: flex; align-items: center;
      justify-content: center; font-size: 10px; font-weight: 700; cursor: default;
      border: 1px solid var(--border); transition: all 0.15s;
    }
    .msg-channel-icon.active { border-color: var(--gold); background: var(--gold-light); color: var(--text); }
    .msg-channel-icon.inactive { opacity: 0.35; }

    /* ── Tasks / Projects ──────────────────────── */

    .task-item {
      display: flex; align-items: center; gap: 10px;
      padding: 10px 16px; border-bottom: 1px solid var(--border);
    }

    .task-item:last-child { border-bottom: none; }

    .task-checkbox {
      width: 18px; height: 18px; border-radius: 4px;
      border: 2px solid var(--border); cursor: pointer; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      transition: all 0.15s;
    }

    .task-checkbox:hover { border-color: var(--gold); }
    .task-checkbox.checked { background: var(--success); border-color: var(--success); }
    .task-checkbox.checked::after { content: '\2713'; color: #fff; font-size: 12px; font-weight: 700; }

    .task-info { flex: 1; }
    .task-title { font-size: 14px; font-weight: 500; }
    .task-title.done { text-decoration: line-through; color: var(--text-light); }
    .task-desc { font-size: 12px; color: var(--text-light); margin-top: 2px; }
    .task-meta { display: flex; gap: 6px; align-items: center; }

    /* Sub-nav tabs */
    .proj-tabs {
      display: flex; gap: 0; border-bottom: 2px solid var(--border); margin-bottom: 16px;
    }
    .proj-tab {
      padding: 8px 18px; font-size: 13px; font-weight: 600; cursor: pointer;
      color: var(--text-light); border-bottom: 2px solid transparent;
      margin-bottom: -2px; transition: all 0.15s; user-select: none;
    }
    .proj-tab:hover { color: var(--text); }
    .proj-tab.active { color: var(--gold); border-bottom-color: var(--gold); }

    /* Filter bar */
    .proj-filters {
      display: flex; gap: 8px; margin-bottom: 14px; align-items: center;
    }
    .proj-filters select {
      padding: 5px 10px; border: 1px solid var(--border); border-radius: 6px;
      font-family: 'Inter', sans-serif; font-size: 12px; background: var(--white);
      outline: none; cursor: pointer; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
    }
    .proj-filters select:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    /* Board columns */
    .proj-board { display: flex; gap: 14px; overflow-x: auto; padding-bottom: 12px; min-height: 200px; }
    .proj-col { min-width: 240px; flex: 1; }
    .proj-col-header {
      font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
      color: var(--text-light); padding: 8px 0; display: flex; align-items: center; gap: 6px;
    }
    .proj-col-header .count {
      background: var(--border); color: var(--text);
      font-size: 11px; padding: 0 6px; border-radius: 8px;
    }
    .proj-col.drag-over {
      background: rgba(226,189,35,0.08); border-radius: 8px;
      outline: 2px dashed var(--gold); outline-offset: -2px;
    }

    /* Task cards on board */
    .proj-card {
      background: var(--white); border: 1px solid var(--border);
      border-radius: var(--radius-md); padding: 10px 12px; margin-bottom: 8px;
      cursor: grab; transition: box-shadow 0.2s var(--ease-out), border-color 0.2s var(--ease-out), opacity 0.15s;
      box-shadow: var(--shadow-card);
    }
    .proj-card:active { cursor: grabbing; }
    .proj-card.dragging { opacity: 0.5; border-color: var(--gold); }
    .proj-card-title { font-size: 13px; font-weight: 600; margin-bottom: 4px; }
    .proj-card-desc { font-size: 12px; color: var(--text-light); margin-bottom: 6px; max-height: 40px; overflow: hidden; line-height: 1.4; }
    .proj-card-tags { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 6px; }
    .proj-card-tag { font-size: 10px; padding: 1px 7px; border-radius: 8px; background: var(--bg); color: var(--text-light); font-weight: 500; }
    .proj-card-tag.suggestion { background: rgba(226,189,35,0.1); color: #92400e; }
    .proj-card-tag.insight { background: #ede9fe; color: #5b21b6; }
    .proj-card-tag.alert { background: #fee2e2; color: #991b1b; }
    .proj-card-tag.action { background: #d1fae5; color: #065f46; }
    .proj-card-agent { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; padding-bottom: 6px; border-bottom: 1px solid var(--border); }
    .proj-card-agent-avatar { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 700; color: #fff; flex-shrink: 0; }
    .proj-card-agent-name { font-size: 12px; font-weight: 600; }
    .proj-card-agent-label { font-size: 10px; color: var(--text-light); margin-left: auto; padding: 1px 6px; border-radius: 8px; background: var(--bg); }
    .proj-card-row { display: flex; align-items: center; gap: 6px; margin-top: 4px; flex-wrap: wrap; }
    .proj-card-due { font-size: 11px; color: var(--text-light); }
    .proj-card-due.overdue { color: var(--danger); font-weight: 600; }
    .proj-card-project { display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--text-light); }
    .proj-card-project .dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
    .proj-card-priority { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 4px; }
    .proj-card-priority.urgent { background: #fee2e2; color: #b91c1c; }
    .proj-card-priority.high { background: #ffedd5; color: #c2410c; }

    /* Subtask progress */
    .subtask-bar { display: flex; gap: 2px; align-items: center; }
    .subtask-bar-track { display: flex; height: 4px; border-radius: 2px; overflow: hidden; width: 60px; background: var(--border); }
    .subtask-bar-fill { height: 100%; background: var(--success); border-radius: 2px; }
    .subtask-bar-label { font-size: 10px; color: var(--text-light); margin-left: 4px; }

    /* Expanded subtasks */
    .proj-card-subtasks { margin-top: 8px; border-top: 1px solid var(--border); padding-top: 6px; }
    .proj-card-subtask { display: flex; align-items: center; gap: 6px; padding: 3px 0; font-size: 12px; }
    .proj-card-subtask .task-checkbox { width: 14px; height: 14px; border-width: 1.5px; }
    .proj-card-subtask .task-checkbox.checked::after { font-size: 10px; }
    .subtask-add-btn { font-size: 11px; color: var(--gold); cursor: pointer; font-weight: 600; margin-top: 4px; }
    .subtask-add-btn:hover { text-decoration: underline; }

    /* Project detail modal */
    .project-detail-modal { width: 680px; max-width: 95vw; max-height: 90vh; overflow-y: auto; padding: 0; }
    .project-detail-modal .pd-header {
      padding: 20px 24px 16px; border-bottom: 1px solid var(--border);
      display: flex; align-items: flex-start; gap: 12px;
    }
    .project-detail-modal .pd-header-left { flex: 1; }
    .project-detail-modal .pd-title-input {
      font-size: 18px; font-weight: 700; color: var(--text); border: none; background: transparent;
      width: 100%; padding: 0; font-family: Barlow, sans-serif; outline: none;
    }
    .project-detail-modal .pd-title-input:focus { border-bottom: 2px solid var(--gold); }
    .project-detail-modal .pd-desc-input {
      font-size: 13px; color: var(--text-light); border: none; background: transparent;
      width: 100%; padding: 4px 0 0; font-family: Barlow, sans-serif; outline: none; resize: none;
      line-height: 1.5;
    }
    .project-detail-modal .pd-desc-input:focus { border-bottom: 1px solid var(--border); }
    .project-detail-modal .pd-progress {
      margin: 12px 0 0; display: flex; align-items: center; gap: 10px;
    }
    .project-detail-modal .pd-progress-bar {
      flex: 1; height: 6px; border-radius: 3px; background: var(--border); overflow: hidden;
    }
    .project-detail-modal .pd-progress-fill {
      height: 100%; background: var(--success); border-radius: 3px; transition: width 0.3s ease;
    }
    .project-detail-modal .pd-progress-label { font-size: 12px; font-weight: 600; color: var(--text-light); white-space: nowrap; }
    .project-detail-modal .pd-body { padding: 16px 24px 24px; }
    .project-detail-modal .pd-section { margin-bottom: 20px; }
    .project-detail-modal .pd-section-header {
      display: flex; align-items: center; justify-content: space-between;
      margin-bottom: 10px;
    }
    .project-detail-modal .pd-section-title {
      font-size: 12px; font-weight: 700; text-transform: uppercase;
      letter-spacing: 0.5px; color: var(--text-light);
    }
    .project-detail-modal .pd-subtask-item {
      display: flex; align-items: center; gap: 8px; padding: 8px 10px;
      border-radius: 8px; border: 1px solid var(--border); margin-bottom: 6px;
      background: var(--white); transition: all 0.15s ease;
    }
    .project-detail-modal .pd-subtask-item:hover { border-color: var(--gold); box-shadow: 0 1px 4px rgba(0,0,0,0.04); }
    .project-detail-modal .pd-subtask-item.done { opacity: 0.6; }
    .project-detail-modal .pd-subtask-item.done .pd-subtask-title { text-decoration: line-through; color: var(--text-light); }
    .project-detail-modal .pd-subtask-title { flex: 1; font-size: 13px; font-weight: 500; color: var(--text); }
    .project-detail-modal .pd-subtask-title input {
      border: none; background: transparent; font-size: 13px; font-weight: 500;
      color: var(--text); width: 100%; font-family: Barlow, sans-serif; outline: none;
    }
    .project-detail-modal .pd-subtask-owner {
      font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 10px;
      cursor: pointer; white-space: nowrap;
    }
    .project-detail-modal .pd-subtask-due {
      font-size: 11px; color: var(--text-dim); cursor: pointer; white-space: nowrap;
    }
    .project-detail-modal .pd-subtask-due.overdue { color: var(--danger); font-weight: 600; }
    .project-detail-modal .pd-subtask-actions { display: flex; gap: 2px; opacity: 0; transition: opacity 0.15s; }
    .project-detail-modal .pd-subtask-item:hover .pd-subtask-actions { opacity: 1; }
    .project-detail-modal .pd-subtask-status {
      font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 10px;
      cursor: pointer; white-space: nowrap; border: 1px solid transparent;
    }
    .project-detail-modal .pd-add-subtask {
      display: flex; align-items: center; gap: 6px; padding: 8px 10px;
      border-radius: 8px; border: 1px dashed var(--border); cursor: pointer;
      font-size: 13px; color: var(--text-light); transition: all 0.15s;
    }
    .project-detail-modal .pd-add-subtask:hover { border-color: var(--gold); color: var(--gold); background: rgba(226,189,35,0.04); }
    .project-detail-modal .pd-notes-textarea {
      width: 100%; border: 1px solid var(--border); border-radius: 8px;
      padding: 10px 12px; font-size: 13px; font-family: Barlow, sans-serif;
      color: var(--text); resize: vertical; min-height: 80px; outline: none;
      transition: border-color 0.15s;
    }
    .project-detail-modal .pd-notes-textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(226,189,35,0.15); }
    .project-detail-modal .pd-activity-item {
      display: flex; gap: 8px; padding: 6px 0; font-size: 12px; color: var(--text-light);
      border-bottom: 1px solid rgba(0,0,0,0.03);
    }
    .project-detail-modal .pd-activity-time { font-size: 11px; color: var(--text-dim); white-space: nowrap; min-width: 80px; }
    .project-detail-modal .pd-tabs {
      display: flex; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 16px;
    }
    .project-detail-modal .pd-tab {
      padding: 8px 16px; font-size: 12px; font-weight: 600; color: var(--text-light);
      cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.15s;
    }
    .project-detail-modal .pd-tab:hover { color: var(--text); }
    .project-detail-modal .pd-tab.active { color: var(--gold); border-bottom-color: var(--gold); }

    /* List view */
    .proj-list-table { width: 100%; border-collapse: collapse; }
    .proj-list-table th {
      text-align: left; font-size: 11px; font-weight: 700; text-transform: uppercase;
      letter-spacing: 0.5px; color: var(--text-light); padding: 8px 10px;
      border-bottom: 2px solid var(--border);
    }
    .proj-list-table td { padding: 8px 10px; font-size: 13px; border-bottom: 1px solid var(--border); vertical-align: middle; }
    .proj-list-table tr:hover { background: var(--bg); }
    .proj-list-expand { cursor: pointer; width: 20px; text-align: center; font-size: 12px; color: var(--text-light); user-select: none; }
    .proj-list-expand:hover { color: var(--text); }
    .proj-list-subtask td { padding-left: 36px; background: #fafbfc; }
    .proj-list-status {
      padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 600;
      cursor: pointer; display: inline-block;
    }
    .proj-list-status.todo { background: #f1f5f9; color: #64748b; }
    .proj-list-status.in_progress { background: rgba(226,189,35,0.1); color: #92400e; }
    .proj-list-status.done { background: #dcfce7; color: #166534; }

    /* Timeline / Gantt */
    .proj-timeline { overflow-x: auto; position: relative; }
    .proj-timeline-header {
      display: flex; border-bottom: 2px solid var(--border); position: sticky; top: 0; background: var(--white); z-index: 2;
    }
    .proj-timeline-header .day-cell {
      min-width: 36px; text-align: center; font-size: 10px; font-weight: 600; color: var(--text-light);
      padding: 4px 0; border-right: 1px solid #f0f0f0;
    }
    .proj-timeline-header .day-cell.today { background: rgba(226,189,35,0.15); color: var(--gold); }
    .proj-timeline-row { display: flex; align-items: center; min-height: 32px; border-bottom: 1px solid #f0f0f0; }
    .proj-timeline-label { width: 180px; flex-shrink: 0; font-size: 12px; font-weight: 500; padding: 4px 8px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .proj-timeline-bars { flex: 1; position: relative; display: flex; align-items: center; height: 32px; }
    .proj-timeline-bar {
      position: absolute; height: 16px; border-radius: 4px; font-size: 10px; color: #fff; font-weight: 600;
      display: flex; align-items: center; padding: 0 6px; white-space: nowrap; overflow: hidden;
    }
    .proj-timeline-group { font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--text-light); padding: 6px 8px; background: #f9fafb; letter-spacing: 0.5px; }

    /* Project cards grid */
    .proj-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
    .proj-project-card {
      background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg);
      padding: 16px; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); cursor: pointer;
      box-shadow: var(--shadow-card);
    }
    .proj-project-card:hover { border-color: var(--gold); box-shadow: var(--shadow-elevated); }
    .proj-project-card-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
    .proj-project-card-header .dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
    .proj-project-card-header .name { font-size: 15px; font-weight: 700; }
    .proj-project-card-desc { font-size: 12px; color: var(--text-light); margin-bottom: 10px; line-height: 1.4; }
    .proj-project-card-stats { display: flex; gap: 12px; font-size: 12px; color: var(--text-light); }
    .proj-project-card-stats span { display: flex; align-items: center; gap: 4px; }
    .proj-project-card-actions { display: flex; gap: 6px; margin-top: 10px; }

    /* ── Projects Unified Layout (side-by-side with Systems) ──── */
    .proj-unified { display: flex; height: calc(100vh - 105px); margin: -20px -24px; }
    .proj-left { flex: 1; min-width: 400px; border-right: 1px solid var(--border); background: var(--white); overflow-y: auto; display: flex; flex-direction: column; }
    .proj-left-content { flex: 1; overflow-y: auto; padding: 20px; }
    .proj-right { width: 380px; flex-shrink: 0; display: flex; flex-direction: column; background: var(--bg); overflow: hidden; }
    .proj-right-header { padding: 14px 18px; background: var(--white); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
    .proj-right-header h3 { font-size: 15px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; margin: 0; }
    .proj-quick-actions { padding: 12px 18px; border-bottom: 1px solid var(--border); background: var(--white); flex-shrink: 0; }
    .proj-quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
    .proj-quick-btn { display: flex; align-items: center; gap: 6px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--white); cursor: pointer; font-size: 11px; font-weight: 500; color: var(--text); font-family: Barlow, sans-serif; text-align: left; transition: all .15s var(--ease-out); }
    .proj-quick-btn:hover { border-color: #6ba73b; background: rgba(107,167,59,0.04); }
    .proj-chat-area { flex: 1; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }
    .proj-chat-input-bar { padding: 12px 18px; border-top: 1px solid var(--border); background: var(--white); display: flex; gap: 8px; flex-shrink: 0; }

    @media (max-width: 768px) {
      .proj-unified { flex-direction: column; height: auto; }
      .proj-left { min-width: 0; border-right: none; border-bottom: 1px solid var(--border); max-height: 60vh; }
      .proj-right { width: 100%; height: 50vh; }
    }

    /* ── Calendar ──────────────────────────────── */

    .cal-nav {
      display: flex; align-items: center; gap: 12px; margin-bottom: 16px;
    }

    .cal-nav-title { font-size: 15px; font-weight: 600; color: var(--text); min-width: 180px; }

    .cal-view-toggle {
      display: flex; gap: 2px; background: var(--bg); border-radius: 6px; padding: 2px; margin-left: auto;
    }
    .cal-view-btn {
      font-size: 12px; font-weight: 500; padding: 4px 12px; border: none; border-radius: 4px;
      cursor: pointer; background: transparent; color: var(--text-light); font-family: 'Inter', sans-serif;
      transition: all .15s;
    }
    .cal-view-btn.active {
      background: var(--gold); color: var(--text); font-weight: 700;
    }
    .cal-view-btn:hover:not(.active) { background: rgba(0,0,0,0.04); }

    .cal-grid {
      display: flex;
      background: var(--white); border: 1px solid var(--border); border-radius: 8px;
      overflow: hidden;
      height: calc(100vh - 260px); overflow-y: auto;
    }

    .cal-time-col { width: 60px; flex-shrink: 0; }
    .cal-day-col { flex: 1; border-left: 1px solid var(--border); min-width: 0; }
    .cal-day-body { position: relative; }

    .cal-day-header {
      padding: 10px 4px; text-align: center;
      font-size: 12px; font-weight: 600; color: var(--text-light);
      text-transform: uppercase; border-bottom: 1px solid var(--border);
      background: var(--bg); position: sticky; top: 0; z-index: 3;
    }

    .cal-day-header.today { color: var(--gold); background: rgba(226,189,35,0.08); }

    .cal-time-label {
      padding: 0 6px; font-size: 11px; color: var(--text-light);
      border-bottom: 1px solid var(--border);
      display: flex; align-items: flex-start; justify-content: flex-end;
      height: 40px; padding-top: 2px;
    }

    .cal-cell {
      border-bottom: 1px solid var(--border);
      height: 40px; padding: 2px; position: relative; z-index: 2; cursor: pointer;
    }

    .cal-cell:hover { background: rgba(226,189,35,0.04); }

    .cal-apt {
      background: var(--gold-light); border-left: 3px solid var(--gold);
      border-radius: 0 4px 4px 0; padding: 2px 6px;
      font-size: 11px; font-weight: 600; color: var(--text);
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      cursor: pointer; line-height: 1.3;
    }

    .cal-apt.cancelled { background: #fee2e2; border-left-color: var(--danger); opacity: 0.6; text-decoration: line-through; }
    .cal-apt.completed { background: #dcfce7; border-left-color: var(--success); }

    .cal-apt .apt-type { font-size: 9px; font-weight: 500; color: var(--text-light); }

    /* ── Google Calendar toggles & events ──────── */
    .cal-toggles {
      display: flex; flex-wrap: wrap; gap: 6px; padding: 8px 12px;
      border-bottom: 1px solid var(--border);
    }
    .cal-toggle-chip {
      display: inline-flex; align-items: center; gap: 5px;
      padding: 4px 10px; border-radius: 16px;
      border: 1px solid var(--border); background: var(--bg);
      font-size: 11px; font-weight: 500; color: var(--text-light);
      cursor: pointer; transition: all .15s;
    }
    .cal-toggle-chip:hover { border-color: #aaa; }
    .cal-toggle-chip.active {
      background: color-mix(in srgb, var(--chip-color, #7986cb) 12%, white);
      border-color: var(--chip-color, #7986cb);
      color: var(--text);
    }
    .cal-toggle-dot {
      width: 8px; height: 8px; border-radius: 50%;
      flex-shrink: 0;
    }
    .cal-gcal-event {
      position: absolute; left: 2px; right: 2px; z-index: 1;
      border-left: 3px solid; border-radius: 0 4px 4px 0;
      padding: 2px 6px; box-sizing: border-box;
      font-size: 10px; font-weight: 500; color: #444;
      overflow: hidden; text-overflow: ellipsis;
      opacity: 0.8; line-height: 1.4;
    }
    .cal-gcal-event .cal-gcal-time { font-weight: 600; }
    .cal-legend {
      display: inline-flex; align-items: center; gap: 10px;
      margin-left: auto; font-size: 10px; color: var(--text-light);
    }
    .cal-legend-item { display: inline-flex; align-items: center; gap: 3px; }
    .cal-legend-dot {
      width: 10px; height: 10px; border-radius: 2px;
      border-left: 3px solid; flex-shrink: 0;
    }

    /* ── Appointment popover ───────────────────── */

    .apt-popover {
      position: fixed; background: var(--white); border: 1px solid var(--border);
      border-radius: 10px; padding: 16px; width: 280px; z-index: 50;
      box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    }

    .apt-popover.hidden { display: none; }
    .apt-popover h4 { font-size: 15px; font-weight: 600; color: var(--text); margin-bottom: 8px; }
    .apt-popover .apt-detail { font-size: 13px; color: var(--text-light); margin-bottom: 4px; }
    .apt-popover .apt-actions { display: flex; gap: 6px; margin-top: 12px; flex-wrap: wrap; }

    /* ── Modal ─────────────────────────────────── */

    .modal-overlay {
      position: fixed; inset: 0; background: rgba(0,0,0,0.4);
      display: flex; align-items: center; justify-content: center; z-index: 100;
    }

    .modal-overlay.hidden { display: none; }

    .modal { background: var(--white); border-radius: var(--radius-lg); padding: 24px; width: 420px; max-width: 90vw; box-shadow: var(--shadow-elevated); }
    .modal h3 { font-size: 16px; font-weight: 600; margin-bottom: 16px; color: var(--text); }

    .form-group { margin-bottom: 12px; }
    .form-group label { display: block; font-size: 12px; font-weight: 600; color: var(--text-light); margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.3px; }

    .form-group input, .form-group select, .form-group textarea {
      width: 100%; padding: 8px 12px; border: 1px solid var(--border);
      border-radius: 6px; font-family: 'Inter', sans-serif; font-size: 13px; outline: none;
      transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
    }

    .form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }
    .form-group label { display: block; font-size: 11px; font-weight: 500; color: var(--text-light); margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.3px; }
    .modal-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 16px; }

    /* ── Login screen ─────────────────────────── */

    .login-screen {
      position: fixed; inset: 0; background: var(--dark);
      display: flex; align-items: center; justify-content: center;
      z-index: 200;
    }

    .login-screen.hidden { display: none; }

    .login-box {
      background: var(--white); border-radius: 12px; padding: 40px;
      width: 360px; max-width: 90vw; text-align: center;
    }

    .login-box h1 {
      font-size: 20px; font-weight: 700; color: var(--gold);
      letter-spacing: 0.5px; margin-bottom: 4px;
    }

    .login-box .subtitle {
      font-size: 13px; color: var(--text-light); margin-bottom: 24px;
    }

    .login-box .form-group { text-align: left; margin-bottom: 14px; }

    .login-box input {
      width: 100%; padding: 10px 14px; border: 1px solid var(--border);
      border-radius: 8px; font-family: 'Inter', sans-serif; font-size: 14px; outline: none;
      transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
    }

    .login-box input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    .login-box .btn-login {
      width: 100%; padding: 12px; border-radius: 8px; border: none;
      background: var(--gold); color: var(--text); font-family: 'Inter', sans-serif;
      font-size: 15px; font-weight: 700; cursor: pointer; margin-top: 8px;
      transition: background 0.15s;
    }

    .login-box .btn-login:hover { background: var(--accent-hover); }

    .login-error {
      color: var(--danger); font-size: 13px; margin-top: 10px;
      display: none; text-align: center;
    }

    /* ── Sidebar bottom (logout + settings) ──── */

    .sidebar-bottom {
      padding: 8px 0;
      border-top: 1px solid var(--border);
    }

        /* ── Dashboard Home ─────────────────────── */

    /* dash-kpi-row defined below with action cards */
    .dash-kpi-card {
      background: var(--white);
      border-radius: var(--radius-lg);
      padding: 20px 22px;
      border: 1px solid var(--border);
      box-shadow: var(--shadow-card);
      transition: all var(--duration-normal) var(--ease-out);
      position: relative;
      overflow: hidden;
    }
    .dash-kpi-card::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 3px;
      background: var(--dusk);
      opacity: 0;
      transition: opacity var(--duration-normal) var(--ease-out);
    }
    .dash-kpi-card:hover {
      box-shadow: var(--shadow-elevated);
      transform: translateY(-2px);
      border-color: rgba(74, 111, 165, 0.2);
    }
    .dash-kpi-card:hover::before { opacity: 1; }
    .dash-kpi-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-dim); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
    .dash-kpi-value { font-size: 32px; font-weight: 700; color: var(--text); line-height: 1; }
    .dash-kpi-trend { font-size: 11px; font-weight: 600; margin-top: 8px; display: flex; align-items: center; gap: 4px; }
    .dash-kpi-trend.up { color: #6ba73b; }
    .dash-kpi-trend.down { color: #ef4444; }
    .dash-kpi-trend.neutral { color: var(--text-light); }

    .dash-grid {
      display: grid;
      grid-template-columns: 1fr 380px;
      gap: 24px;
      align-items: start;
    }

    .dash-section-title {
      font-size: 15px;
      font-weight: 700;
      color: var(--text);
      margin: 0 0 12px 0;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .dash-section-title svg { width: 18px; height: 18px; flex-shrink: 0; }

    .dash-activity-item {
      padding: 12px 16px;
      border-bottom: 1px solid #f0f0f0;
      display: flex;
      align-items: center;
      gap: 10px;
      cursor: pointer;
      transition: background 0.15s;
    }
    .dash-activity-item:hover { background: #fafafa; }
    .dash-activity-item:last-child { border-bottom: none; }

    .dash-avatar {
      width: 36px; height: 36px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-weight: 600; font-size: 13px; flex-shrink: 0;
    }

    .dash-channel-badge {
      display: inline-block;
      font-size: 9px;
      padding: 1px 5px;
      border-radius: 4px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.3px;
      vertical-align: middle;
      margin-left: 4px;
    }

    .dash-quick-btn {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 12px 16px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--surface-1);
      cursor: pointer;
      font-size: 13px;
      font-weight: 500;
      color: var(--text);
      transition: all 0.2s cubic-bezier(0.22, 1, 0.36, 1);
      width: 100%;
      text-align: left;
    }
    .dash-quick-btn:hover { border-color: var(--gold); background: rgba(226,189,35,0.04); transform: translateY(-1px); box-shadow: 0 2px 8px rgba(0,0,0,0.06); }
    .dash-quick-btn svg { width: 18px; height: 18px; color: #4a6fa5; flex-shrink: 0; }

    .dash-agent-card {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 14px;
      border-radius: 8px;
      background: #f8f9fa;
      transition: all 0.15s;
    }
    .dash-agent-card:hover { background: #f0f1f3; }
    .dash-agent-dot {
      width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
    }

    /* Action cards — actions-first dashboard */
    .dash-action-card {
      background: var(--white);
      border-radius: var(--radius-md);
      border: 1px solid var(--border);
      border-left: 3px solid var(--gold);
      box-shadow: var(--shadow-card);
      overflow: hidden;
    }
    .dash-action-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 10px 16px;
      border-bottom: 1px solid #f0f0f0;
    }
    .dash-action-label {
      font-size: 12px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.3px;
      color: var(--text-light);
    }
    .dash-action-count {
      font-size: 11px;
      font-weight: 700;
      background: var(--gold);
      color: var(--dark);
      padding: 1px 8px;
      border-radius: 10px;
      min-width: 20px;
      text-align: center;
    }
    .dash-stat-danger .dash-kpi-value { color: var(--danger); }
    .dash-stat-danger { border-color: rgba(239, 68, 68, 0.3); }

    /* Compact action row */
    .dash-action-row {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 7px 16px;
      border-bottom: 1px solid #f5f5f5;
      cursor: pointer;
      transition: background 0.12s;
      font-size: 13px;
    }
    .dash-action-row:hover { background: #fafafa; }
    .dash-action-row:last-child { border-bottom: none; }
    .dash-action-name { font-weight: 600; color: var(--text); white-space: nowrap; }
    .dash-action-preview { flex: 1; min-width: 0; color: #888; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .dash-action-time { font-size: 10px; color: var(--text-light); white-space: nowrap; flex-shrink: 0; }
    .dash-unread-badge { background: #ef4444; color: #fff; font-size: 10px; font-weight: 700; padding: 0 5px; border-radius: 8px; flex-shrink: 0; }
    .dash-action-label { display: flex; align-items: center; gap: 6px; }

    /* Inline action buttons */
    .dash-action-btns { display: flex; gap: 4px; flex-shrink: 0; opacity: 0; transition: opacity 0.15s; }
    .dash-action-row:hover .dash-action-btns { opacity: 1; }
    .dash-action-btn {
      padding: 2px 8px;
      border: 1px solid var(--border);
      border-radius: 4px;
      background: var(--white);
      font-size: 11px;
      font-weight: 600;
      color: var(--dusk);
      cursor: pointer;
      white-space: nowrap;
      transition: all 0.12s;
    }
    .dash-action-btn:hover { background: var(--dusk); color: #fff; border-color: var(--dusk); }
    .dash-action-btn-muted { color: var(--text-light); }
    .dash-action-btn-muted:hover { background: #ef4444; color: #fff; border-color: #ef4444; }

    /* Scrollable action list */
    .dash-action-list { overflow-y: auto; }
    .dash-action-list::-webkit-scrollbar { width: 4px; }
    .dash-action-list::-webkit-scrollbar-thumb { background: #ddd; border-radius: 2px; }

    .dash-kpi-row {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: var(--sp-md);
      margin-bottom: var(--sp-xl);
    }

    @media (max-width: 1024px) {
      .dash-kpi-row { grid-template-columns: repeat(3, 1fr); }
      .dash-grid { grid-template-columns: 1fr; }
    }
    @media (max-width: 600px) {
      .dash-kpi-row { grid-template-columns: 1fr 1fr; gap: 10px; }
      .dash-kpi-card { padding: 14px 16px; }
      .dash-kpi-value { font-size: 22px; }
    }

/* ── Settings view ────────────────────────── */

    .settings-grid {
      display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
    }

    .settings-panel {
      background: var(--white); border: 1px solid var(--border);
      border-radius: var(--radius-md); padding: 20px;
      box-shadow: var(--shadow-card);
    }

    .settings-panel h3 {
      font-size: 15px; font-weight: 600; color: var(--text);
      margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
    }

    .settings-panel .setting-row {
      display: flex; align-items: center; justify-content: space-between;
      padding: 8px 0; border-bottom: 1px solid var(--border);
      font-size: 13px;
    }

    .settings-panel .setting-row:last-child { border-bottom: none; }
    .settings-panel .setting-label { color: var(--text-light); font-weight: 500; }
    .settings-panel .setting-value { font-weight: 600; color: var(--text); }
    .settings-panel .setting-badge { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 600; }
    .settings-panel .connected { background: #dcfce7; color: #166534; }
    .settings-panel .not-connected { background: #fee2e2; color: #b91c1c; }

    .settings-panel input[type="text"], .settings-panel input[type="number"] {
      padding: 6px 10px; border: 1px solid var(--border); border-radius: 6px;
      font-family: 'Inter', sans-serif; font-size: 13px; outline: none; width: 120px;
      transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
    }

    .settings-panel input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    .settings-tabs {
      display: flex; gap: 0; border-bottom: 2px solid var(--border);
      margin-bottom: 0;
    }
    .settings-tab {
      padding: 10px 22px; border: none; background: none;
      font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 500;
      color: var(--text-light); cursor: pointer;
      border-bottom: 2px solid transparent; margin-bottom: -2px;
      display: flex; align-items: center; gap: 6px;
      transition: color 0.15s, border-color 0.15s;
    }
    .settings-tab:hover { color: var(--text); }
    .settings-tab.active {
      font-weight: 700; color: var(--gold);
      border-bottom-color: var(--gold);
    }
    .settings-tab.active svg { stroke: var(--gold); }

    .team-member {
      display: flex; align-items: center; gap: 10px; padding: 8px 0;
      border-bottom: 1px solid var(--border);
    }

    .team-member:last-child { border-bottom: none; }

    .team-colour {
      width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
    }

    /* ── AI Search bar (topbar) ─────────────────── */

    .ai-search-wrap {
      position: relative; flex: 1; max-width: 400px; margin: 0 20px;
    }

    .ai-search-wrap input {
      width: 100%; padding: 8px 14px 8px 34px;
      border: 1px solid var(--border); border-radius: 8px;
      font-family: 'Inter', sans-serif; font-size: 13px;
      outline: none; background: var(--bg); color: var(--text);
      transition: border-color 0.2s var(--ease-out), background 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
    }

    .ai-search-wrap input:focus { border-color: var(--gold); background: var(--white); box-shadow: 0 0 0 3px var(--accent-glow); }
    .ai-search-wrap input::placeholder { color: var(--text-light); }

    .ai-search-icon {
      position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
      width: 16px; height: 16px; color: var(--text-light); pointer-events: none;
    }

    .ai-answer {
      position: absolute; top: calc(100% + 6px); left: 0; right: 0;
      background: var(--white); border: 1px solid var(--border);
      border-radius: 10px; padding: 14px 16px;
      box-shadow: 0 8px 24px rgba(0,0,0,0.1);
      font-size: 14px; line-height: 1.5; color: var(--text);
      z-index: 80; animation: aiSlideIn 0.15s ease;
    }

    .ai-answer.hidden { display: none; }

    .ai-answer .ai-answer-text { margin: 0; }

    .ai-answer .ai-answer-close {
      position: absolute; top: 8px; right: 10px;
      background: none; border: none; cursor: pointer;
      color: var(--text-light); font-size: 16px; line-height: 1;
    }

    .ai-answer .ai-answer-close:hover { color: var(--text); }

    .ai-answer.thinking { color: var(--text-light); font-style: italic; }

    @keyframes aiSlideIn {
      from { opacity: 0; transform: translateY(-4px); }
      to { opacity: 1; transform: translateY(0); }
    }

    /* ── Notification Bell ────────────────────────── */

    .notif-bell {
      position: relative; cursor: pointer; padding: 6px;
      display: flex; align-items: center; justify-content: center;
      border-radius: 6px; transition: background 0.15s;
    }
    .notif-bell:hover { background: var(--bg); }
    .notif-bell svg { width: 20px; height: 20px; color: var(--text-light); }

    .notif-badge {
      position: absolute; top: 2px; right: 2px;
      background: var(--danger); color: #fff;
      font-size: 10px; font-weight: 700;
      min-width: 16px; height: 16px;
      border-radius: 8px; display: none;
      align-items: center; justify-content: center;
      padding: 0 4px; line-height: 1;
    }

    .notif-dropdown {
      position: absolute; top: calc(100% + 8px); right: 0;
      width: 400px; max-height: 500px; overflow-y: auto;
      background: var(--white); border: 1px solid var(--border);
      border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.12);
      z-index: 90; display: none;
    }
    .notif-dropdown.open { display: block; animation: aiSlideIn 0.15s ease; }

    .notif-dropdown-header {
      padding: 12px 16px; border-bottom: 1px solid var(--border);
      display: flex; align-items: center; justify-content: space-between;
      font-size: 14px; font-weight: 600; color: var(--text);
    }

    .notif-empty {
      padding: 32px 16px; text-align: center;
      color: var(--text-light); font-size: 13px;
    }

    .notif-item {
      padding: 12px 16px; border-bottom: 1px solid var(--border);
      display: flex; gap: 10px; cursor: pointer; transition: background 0.1s;
    }
    .notif-item:last-child { border-bottom: none; }
    .notif-item:hover { background: var(--bg); }
    .notif-item.unread { background: rgba(226,189,35,0.06); }

    .notif-agent {
      width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      font-size: 13px; font-weight: 700; color: #fff;
    }

    .notif-content { flex: 1; min-width: 0; }

    .notif-top { display: flex; align-items: center; gap: 6px; margin-bottom: 2px; }

    .notif-title { font-size: 13px; font-weight: 600; color: var(--text); }

    .notif-priority-dot {
      width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
    }
    .notif-priority-dot.urgent { background: var(--danger); }
    .notif-priority-dot.high { background: var(--warning); }

    .notif-type-badge {
      font-size: 10px; font-weight: 600; padding: 1px 6px;
      border-radius: 8px; text-transform: uppercase; letter-spacing: 0.3px;
      background: var(--bg); color: var(--text-light); border: 1px solid var(--border);
    }
    .notif-type-badge.alert { background: #fef2f2; color: #dc2626; border-color: #fecaca; }
    .notif-type-badge.action_required { background: rgba(245,158,11,0.1); color: #92400e; border-color: rgba(245,158,11,0.3); }
    .notif-type-badge.insight { background: rgba(226,189,35,0.1); color: #92400e; border-color: rgba(245,158,11,0.3); }
    .notif-type-badge.reminder { background: #f0fdf4; color: #16a34a; border-color: #bbf7d0; }

    .notif-body {
      font-size: 12px; color: var(--text-light); line-height: 1.4;
      display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
      overflow: hidden; margin-top: 2px;
    }

    .notif-meta {
      display: flex; align-items: center; gap: 8px; margin-top: 6px;
    }

    .notif-time { font-size: 11px; color: var(--text-light); }

    .notif-actions {
      display: flex; gap: 4px; margin-left: auto;
    }

    .notif-action-btn {
      background: none; border: 1px solid var(--border); border-radius: 4px;
      padding: 2px 6px; cursor: pointer; font-size: 11px; color: var(--text-light);
      transition: all 0.1s; display: flex; align-items: center; gap: 3px;
    }
    .notif-action-btn:hover { background: var(--bg); }
    .notif-action-btn.resolve { color: var(--success); border-color: var(--success); }
    .notif-action-btn.resolve:hover { background: #f0fdf4; }
    .notif-action-btn.dismiss:hover { color: var(--danger); border-color: var(--danger); background: #fef2f2; }

    /* ── Wellbeing Widget ────────────────────── */

    .wellbeing-widget {
      position: relative; display: flex; align-items: center; gap: 6px;
      cursor: pointer; padding: 4px 8px; border-radius: 6px;
      transition: background 0.2s var(--ease-out);
      user-select: none; font-family: 'Inter', sans-serif;
    }
    .wellbeing-widget:hover { background: rgba(245,158,11,0.08); }

    .wellbeing-dot {
      width: 10px; height: 10px; border-radius: 50%;
      background: var(--success); transition: background 0.5s, box-shadow 0.5s;
      box-shadow: 0 0 6px rgba(107,167,59,0.4); flex-shrink: 0;
    }
    .wellbeing-dot.green { background: var(--success); box-shadow: 0 0 6px rgba(107,167,59,0.4); }
    .wellbeing-dot.amber { background: var(--warning); box-shadow: 0 0 6px rgba(245,158,11,0.4); }
    .wellbeing-dot.red { background: var(--danger); box-shadow: 0 0 6px rgba(239,68,68,0.4); }
    .wellbeing-dot.pulse {
      animation: wellbeingPulse 1.5s ease-in-out infinite;
    }
    @keyframes wellbeingPulse {
      0%, 100% { transform: scale(1); }
      50% { transform: scale(1.3); }
    }

    .wellbeing-flash {
      font-size: 11px; font-weight: 500; color: var(--text-dim);
      white-space: nowrap; overflow: hidden; max-width: 0;
      opacity: 0; transition: max-width 0.4s var(--ease-out), opacity 0.3s ease;
    }
    .wellbeing-flash.show {
      max-width: 200px; opacity: 1;
    }
    .wellbeing-flash.hide {
      max-width: 0; opacity: 0;
      transition: max-width 0.3s ease, opacity 0.3s ease;
    }

    .wellbeing-dropdown {
      position: absolute; top: calc(100% + 8px); right: 0;
      width: 280px; background: var(--white); border: 1px solid var(--border);
      border-radius: 8px; box-shadow: 0 1px 3px rgba(0,0,0,0.06);
      z-index: 100; display: none; padding: 0; overflow: hidden;
    }
    .wellbeing-dropdown.open {
      display: block; animation: wellbeingDropIn 0.2s var(--ease-out);
    }
    @keyframes wellbeingDropIn {
      from { opacity: 0; transform: translateY(-6px); }
      to { opacity: 1; transform: translateY(0); }
    }

    .wellbeing-dd-header {
      padding: 12px 14px; border-bottom: 1px solid var(--border);
      display: flex; align-items: center; gap: 8px;
    }
    .wellbeing-avatar {
      width: 24px; height: 24px; border-radius: 50%; background: #f59e0b;
      color: #1a1a2e; display: flex; align-items: center; justify-content: center;
      font-size: 11px; font-weight: 700; flex-shrink: 0;
    }
    .wellbeing-dd-header .wellbeing-name {
      font-size: 13px; font-weight: 700; color: var(--text);
    }
    .wellbeing-dd-header .wellbeing-role {
      font-size: 10px; color: var(--text-dim);
    }

    .wellbeing-dd-section {
      padding: 10px 14px; border-bottom: 1px solid var(--border);
    }
    .wellbeing-dd-section:last-child { border-bottom: none; }

    .wellbeing-dd-label {
      font-size: 11px; font-weight: 600; text-transform: uppercase;
      letter-spacing: 0.5px; color: var(--text-dim); margin-bottom: 6px;
    }

    .wellbeing-session-time {
      font-size: 22px; font-weight: 700; color: var(--text);
      font-variant-numeric: tabular-nums;
    }
    .wellbeing-session-status {
      font-size: 11px; color: var(--text-dim); margin-top: 2px;
    }

    .wellbeing-suggestion-box {
      padding: 8px 10px; background: rgba(245,158,11,0.08);
      border-radius: 6px; font-size: 12px; color: var(--text);
      line-height: 1.4; border-left: 3px solid #f59e0b;
    }

    .wellbeing-focus-row {
      display: flex; align-items: center; gap: 10px;
    }
    .wellbeing-focus-display {
      font-size: 20px; font-weight: 700; color: var(--text);
      font-variant-numeric: tabular-nums; min-width: 56px;
    }
    .wellbeing-focus-btns { display: flex; gap: 4px; flex-wrap: wrap; }
    .wellbeing-focus-btn {
      padding: 5px 10px; border-radius: 6px; border: none; cursor: pointer;
      font-size: 11px; font-weight: 600; transition: all 0.15s;
      font-family: 'Inter', sans-serif;
    }
    .wellbeing-focus-btn.primary { background: var(--gold); color: var(--text); }
    .wellbeing-focus-btn.primary:hover { background: var(--accent-hover); }
    .wellbeing-focus-btn.secondary { background: var(--bg); color: var(--text-light); border: 1px solid var(--border); }
    .wellbeing-focus-btn.secondary:hover { background: var(--border); }
    .wellbeing-focus-label {
      font-size: 10px; color: var(--text-dim); margin-top: 2px;
    }

    .wellbeing-done-btn {
      width: 100%; padding: 8px; border: none; border-radius: 6px;
      background: var(--bg); color: var(--text-light); font-size: 12px;
      font-weight: 600; cursor: pointer; transition: all 0.15s;
      font-family: 'Inter', sans-serif; border: 1px solid var(--border);
    }
    .wellbeing-done-btn:hover { background: var(--dark); color: var(--white); }

    /* ── Toast notifications ───────────────────── */

    .toast-container {
      position: fixed; top: 16px; right: 16px; z-index: 10000;
      display: flex; flex-direction: column; gap: 8px; pointer-events: none;
    }
    .toast {
      pointer-events: auto;
      background: var(--dark); color: #fff; padding: 12px 20px;
      border-radius: 8px; font-size: 14px; font-weight: 500;
      box-shadow: 0 8px 24px rgba(0,0,0,0.2);
      display: flex; align-items: center; gap: 10px;
      animation: toastIn 0.3s ease-out;
      max-width: 380px; line-height: 1.4;
    }
    .toast.toast-success { border-left: 4px solid var(--success); }
    .toast.toast-error { border-left: 4px solid var(--danger); }
    .toast.toast-warning { border-left: 4px solid var(--warning); }
    .toast.toast-info { border-left: 4px solid var(--gold); }
    .toast.toast-out { animation: toastOut 0.3s ease-in forwards; }
    .toast-icon { font-size: 18px; flex-shrink: 0; }
    @keyframes toastIn { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }
    @keyframes toastOut { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(40px); } }

    /* ── Skeleton loaders ─────────────────────── */

    .skeleton {
      background: linear-gradient(90deg, var(--border) 25%, var(--bg) 50%, var(--border) 75%);
      background-size: 200% 100%;
      animation: shimmer 1.5s infinite;
      border-radius: var(--radius-md);
    }
    .skeleton-line { height: 14px; margin-bottom: 10px; }
    .skeleton-line.short { width: 60%; }
    .skeleton-line.medium { width: 80%; }
    .skeleton-card {
      background: var(--white); border-radius: 10px; padding: 20px;
      border: 1px solid var(--border);
    }
    .skeleton-card .skeleton-avatar { width: 40px; height: 40px; border-radius: 50%; }
    .skeleton-row { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
    @keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

    /* ── Empty states ─────────────────────────── */

    .empty-state {
      text-align: center; padding: 60px 24px; color: var(--text-light);
    }
    .empty-state-icon {
      font-size: 48px; margin-bottom: 16px; opacity: 0.4;
    }
    .empty-state h3 {
      font-size: 18px; font-weight: 600; color: var(--text); margin-bottom: 8px;
    }
    .empty-state p {
      font-size: 14px; max-width: 360px; margin: 0 auto 20px; line-height: 1.6;
    }
    .empty-state .btn { display: inline-flex; }

    /* ── Error boundary ───────────────────────── */

    .error-boundary {
      text-align: center; padding: 40px 24px;
      background: #fef2f2; border: 1px solid #fecaca; border-radius: 10px; margin: 20px;
    }
    .error-boundary h3 { color: var(--danger); font-size: 16px; margin-bottom: 8px; }
    .error-boundary p { color: var(--text-light); font-size: 14px; margin-bottom: 16px; }
    .error-boundary .btn { background: var(--danger); color: #fff; }
    .error-boundary .btn:hover { opacity: 0.9; }

    /* ── Contexts & Skills View ────────────────────── */
    .ctx-layout { display: flex; height: calc(100vh - 105px); margin: -20px -24px; }
    .ctx-sidebar { width: 260px; flex-shrink: 0; border-right: 1px solid var(--border); background: var(--surface-1); overflow-y: auto; }
    .ctx-sidebar-header { padding: 16px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text-dim); border-bottom: 1px solid var(--border); }
    .ctx-card { padding: 14px 16px; cursor: pointer; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 12px; transition: all 0.2s var(--ease-out); border-left: 3px solid transparent; }
    .ctx-card:hover { background: rgba(226,189,35,0.04); }
    .ctx-card.selected { background: rgba(226,189,35,0.08); border-left-color: var(--gold); }
    .ctx-card-avatar { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; color: var(--surface-1); flex-shrink: 0; }
    .ctx-card-info { flex: 1; min-width: 0; }
    .ctx-card-name { font-size: 13px; font-weight: 700; color: var(--text); }
    .ctx-card-role { font-size: 11px; color: var(--text-light); margin-top: 1px; }
    .ctx-card-meta { font-size: 10px; color: var(--text-dim); margin-top: 3px; display: flex; gap: 8px; }
    .ctx-main { flex: 1; display: flex; flex-direction: column; background: var(--bg); min-width: 0; overflow: hidden; }
    .ctx-main-header { padding: 16px 24px; background: var(--surface-1); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
    .ctx-main-title { display: flex; align-items: center; gap: 12px; }
    .ctx-main-avatar { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; color: var(--surface-1); flex-shrink: 0; }
    .ctx-main-name { font-size: 16px; font-weight: 700; color: var(--text); }
    .ctx-main-role { font-size: 12px; color: var(--text-light); }
    .ctx-main-stats { display: flex; align-items: center; gap: 12px; }
    .ctx-stat-cost { font-size: 12px; font-weight: 700; color: var(--gold); }
    .ctx-stat-calls { font-size: 11px; color: var(--text-dim); }
    .ctx-tabs { display: flex; gap: 0; border-bottom: 2px solid var(--border); background: var(--surface-1); flex-shrink: 0; }
    .ctx-tab { padding: 10px 20px; font-size: 13px; font-weight: 600; cursor: pointer; color: var(--text-light); border-bottom: 2px solid transparent; margin-bottom: -2px; transition: all 0.15s; user-select: none; }
    .ctx-tab:hover { color: var(--text); }
    .ctx-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
    .ctx-content { flex: 1; overflow: hidden; display: flex; flex-direction: column; }
    .ctx-empty { flex: 1; display: flex; align-items: center; justify-content: center; color: var(--text-dim); font-size: 14px; }

    /* ── Instruct (Upgrade) Panel ──────────────────── */
    .ctx-instruct { flex: 1; display: flex; flex-direction: column; padding: 24px; gap: 20px; overflow-y: auto; }
    .ctx-instruct-hero { text-align: center; padding: 8px 0; }
    .ctx-instruct-title { font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
    .ctx-instruct-desc { font-size: 13px; color: var(--text-light); }
    .ctx-instruct-input { display: flex; gap: 10px; }
    .ctx-instruct-input textarea { flex: 1; padding: 14px 16px; border: 2px solid var(--border); border-radius: 10px; font-family: 'Barlow', sans-serif; font-size: 14px; line-height: 1.5; resize: none; outline: none; min-height: 60px; max-height: 120px; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .ctx-instruct-input textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 4px var(--accent-glow); }
    .ctx-instruct-input button { align-self: flex-end; padding: 12px 24px; font-size: 14px; font-weight: 700; }
    .ctx-instruct-examples { text-align: center; padding: 20px; opacity: 0.6; }
    .ctx-instruct-examples-title { font-size: 13px; font-weight: 700; color: var(--text-light); margin-bottom: 12px; }
    .ctx-instruct-example { font-size: 13px; color: var(--text-light); line-height: 1.6; margin-bottom: 8px; font-style: italic; }

    /* ── Proposed Change Card ──────────────────────── */
    .ctx-proposed { border: 1px solid var(--border); border-radius: 10px; background: var(--surface-1); overflow: hidden; animation: slideUp 0.3s var(--ease-out); }
    .ctx-proposed-error { border-color: var(--danger); }
    .ctx-proposed-header { padding: 14px 18px; background: var(--surface-2); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
    .ctx-proposed-label { font-size: 13px; font-weight: 700; color: var(--text); }
    .ctx-proposed-target { font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 9999px; background: rgba(226,189,35,0.12); color: var(--gold); }
    .ctx-proposed-meta { padding: 10px 18px; display: flex; flex-wrap: wrap; gap: 6px; border-bottom: 1px solid var(--border); }
    .ctx-tag { font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 9999px; }
    .ctx-tag-tokens { background: rgba(74,111,165,0.1); color: #4a6fa5; }
    .ctx-tag-stage { background: rgba(107,167,59,0.1); color: #6ba73b; }
    .ctx-tag-warn { background: rgba(239,68,68,0.1); color: #ef4444; }
    .ctx-proposed-body { padding: 14px 18px; font-size: 13px; color: var(--text-light); line-height: 1.5; border-bottom: 1px solid var(--border); }
    .ctx-proposed-diff { padding: 14px 18px; font-family: 'Fira Code', 'Cascadia Code', monospace; font-size: 12px; line-height: 1.7; white-space: pre-wrap; background: rgba(34,134,58,0.03); border-bottom: 1px solid var(--border); }
    .ctx-diff-add { color: #22863a; padding: 1px 4px; }
    .ctx-proposed-audit { padding: 10px 18px; font-size: 12px; border-bottom: 1px solid var(--border); }
    .ctx-audit-ok { color: var(--success); }
    .ctx-audit-warn { color: #f59e0b; }
    .ctx-proposed-actions { padding: 14px 18px; display: flex; gap: 8px; align-items: center; }
    .ctx-proposed-note { font-size: 12px; color: var(--text-light); }

    /* ── Skills Grid ──────────────────────────────── */
    .ctx-skills-grid { flex: 1; padding: 20px; overflow-y: auto; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; align-content: start; }
    .ctx-skill-card { background: var(--surface-1); border: 1px solid var(--border); border-radius: 10px; padding: 16px; cursor: pointer; transition: all 0.2s var(--ease-out); }
    .ctx-skill-card:hover { border-color: var(--gold); box-shadow: 0 2px 8px rgba(226,189,35,0.1); transform: translateY(-1px); }
    .ctx-skill-inactive { opacity: 0.5; }
    .ctx-skill-soul { border-color: var(--gold); border-width: 2px; }
    .ctx-skill-card-icon { margin-bottom: 8px; }
    .ctx-skill-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
    .ctx-skill-card-name { font-size: 13px; font-weight: 700; color: var(--text); }
    .ctx-skill-card-desc { font-size: 11px; color: var(--text-light); line-height: 1.4; }
    .ctx-skill-card-tokens { font-size: 10px; color: var(--text-dim); margin-top: 8px; font-weight: 600; }
    .ctx-skill-toggle { position: relative; width: 30px; height: 16px; flex-shrink: 0; cursor: pointer; }
    .ctx-skill-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
    .ctx-toggle-track { position: absolute; top: 0; left: 0; right: 0; bottom: 0; border-radius: 8px; transition: 0.2s; background: #d1d5db; }
    .ctx-toggle-track::before { content: ''; position: absolute; top: 2px; left: 2px; width: 12px; height: 12px; background: var(--surface-1); border-radius: 50%; transition: 0.2s; box-shadow: 0 1px 2px rgba(0,0,0,0.2); }
    .ctx-skill-toggle input:checked + .ctx-toggle-track::before { left: 16px; }
    .ctx-stage-link { padding: 12px 20px; border-top: 1px solid var(--border); text-align: center; }

    /* ── Scenarios (Test) Panel ────────────────────── */
    .ctx-scenarios { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
    .ctx-scenario-presets { display: flex; flex-wrap: wrap; gap: 6px; padding: 14px 20px; border-bottom: 1px solid var(--border); background: var(--surface-1); }
    .ctx-scenario-btn { padding: 6px 14px; border: 1px solid var(--border); border-radius: 20px; background: var(--surface-1); cursor: pointer; font-family: 'Barlow', sans-serif; font-size: 11px; font-weight: 600; color: var(--text-light); transition: all 0.2s var(--ease-out); }
    .ctx-scenario-btn:hover { border-color: var(--gold); color: var(--text); background: rgba(226,189,35,0.06); }
    .ctx-scenario-context { padding: 10px 20px; background: var(--surface-1); border-bottom: 1px solid var(--border); }
    .ctx-scenario-context textarea { width: 100%; padding: 8px 12px; border: 1px solid var(--border); border-radius: 6px; font-size: 12px; font-family: 'Barlow', sans-serif; resize: vertical; outline: none; box-sizing: border-box; }
    .ctx-chat-area { flex: 1; overflow-y: auto; padding: 16px 20px; display: flex; flex-direction: column; gap: 10px; }
    .ctx-chat-empty { text-align: center; color: var(--text-dim); padding: 40px 16px; font-size: 13px; }
    .ctx-chat-msg { max-width: 85%; padding: 10px 14px; border-radius: 12px; font-size: 13px; line-height: 1.55; }
    .ctx-msg-user { align-self: flex-end; background: var(--gold); color: var(--dark); border-radius: 12px 12px 4px 12px; }
    .ctx-msg-bot { align-self: flex-start; background: var(--surface-1); color: var(--text); border: 1px solid var(--border); border-radius: 12px 12px 12px 4px; }
    .ctx-msg-tokens { font-size: 10px; opacity: 0.5; margin-top: 3px; }
    .ctx-chat-input { padding: 12px 16px; background: var(--surface-1); border-top: 1px solid var(--border); display: flex; gap: 8px; flex-shrink: 0; }
    .ctx-chat-input input { flex: 1; padding: 10px 14px; border: 1px solid var(--border); border-radius: 6px; font-family: 'Barlow', sans-serif; font-size: 13px; outline: none; transition: border-color 0.2s; }
    .ctx-chat-input input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    /* ── Raw Editor Panel ─────────────────────────── */
    .ctx-raw-picker { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px; }
    .ctx-raw-picker-title { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 16px; }
    .ctx-raw-list { display: flex; flex-direction: column; gap: 4px; width: 100%; max-width: 300px; }
    .ctx-raw-item { padding: 10px 14px; border: 1px solid var(--border); border-radius: 6px; cursor: pointer; font-size: 13px; font-family: 'Fira Code', monospace; color: var(--text-light); transition: all 0.15s; background: var(--surface-1); }
    .ctx-raw-item:hover { border-color: var(--gold); color: var(--text); }
    .ctx-raw-editor { flex: 1; display: flex; flex-direction: column; padding: 16px 20px; gap: 12px; overflow: hidden; }
    .ctx-raw-header { display: flex; align-items: center; gap: 12px; flex-shrink: 0; flex-wrap: wrap; }
    .ctx-raw-badge { font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 9999px; background: rgba(74,111,165,0.1); color: #4a6fa5; }
    .ctx-raw-status { font-size: 11px; color: var(--text-light); }
    .ctx-raw-status.ctx-status-ok { color: var(--success); }
    .ctx-raw-status.ctx-status-err { color: var(--danger); }
    .ctx-raw-btns { margin-left: auto; display: flex; gap: 6px; }
    .ctx-raw-textarea { flex: 1; padding: 14px; border: 1px solid var(--border); border-radius: 8px; font-family: 'Fira Code', 'Cascadia Code', monospace; font-size: 13px; line-height: 1.6; resize: none; outline: none; transition: border-color 0.2s; }
    .ctx-raw-textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    /* ── Stage Map Overlay ─────────────────────────── */
    .ctx-stage-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 300; display: flex; align-items: center; justify-content: center; }
    .ctx-stage-modal { background: var(--surface-1); border-radius: 12px; width: 90%; max-width: 600px; max-height: 80vh; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
    .ctx-stage-modal-header { padding: 16px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; font-size: 15px; font-weight: 700; color: var(--text); }
    .ctx-stage-modal-body { padding: 20px; overflow-y: auto; display: flex; flex-direction: column; gap: 16px; }
    .ctx-stage-row { }
    .ctx-stage-row-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
    .ctx-stage-name { font-size: 13px; font-weight: 700; color: var(--text); text-transform: capitalize; }
    .ctx-stage-pct { font-size: 11px; font-weight: 600; }
    .ctx-stage-bar { height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; margin-bottom: 8px; }
    .ctx-stage-fill { height: 100%; border-radius: 3px; transition: width 0.3s; }
    .ctx-stage-skills { display: flex; flex-wrap: wrap; gap: 4px; }
    .ctx-stage-skill { font-size: 11px; padding: 2px 8px; background: var(--surface-2); border-radius: 4px; color: var(--text-light); }
    .ctx-stage-skill small { color: var(--text-dim); }

    @keyframes slideUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
    @keyframes slideIn { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }

    /* ── Responsive ────────────────────────────── */

    @media (max-width: 768px) {
      .sidebar { display: none !important; }
      .sidebar.mobile-open { display: flex !important; position: fixed; left: 0; top: 0; bottom: 0; z-index: 200; width: 260px; transform: none; }
      .conv-list { width: 100%; border-right: none; }
      .conv-detail { display: none; position: fixed; inset: 0; z-index: 150; width: 100% !important; background: var(--bg); }
      .conv-detail.mobile-open { display: flex !important; flex-direction: column; }
      .pipeline-board { flex-direction: column; }
      .cal-grid { font-size: 10px; }
      .notif-dropdown { width: 320px; right: -60px; }
      .settings-grid { grid-template-columns: 1fr; }
      .settings-tabs { overflow-x: auto; }
      .settings-tab { padding: 8px 14px; font-size: 12px; white-space: nowrap; }
      .msg-popover { width: 100% !important; left: 0 !important; right: 0 !important; bottom: 0 !important; top: auto !important; border-radius: 10px 10px 0 0; max-height: 70vh; }
      .msg-history { height: 200px; }
      .conversation-split { flex-direction: column; }
      .contacts-layout { flex-direction: column; }
      .contact-detail-panel { width: 100% !important; position: fixed !important; inset: 0 !important; z-index: 99; bottom: 60px !important; }
    }

    /* ── Content Studio ──────────────────────────── */
    /* ── Content Studio — Feed ──────────────────────── */
    .cs-view-toggle { display: flex; gap: 4px; }
    .cs-view-btn { padding: 6px 14px; border-radius: 20px; font-size: 13px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--white); color: var(--text); transition: all .15s; }
    .cs-view-btn:hover { background: var(--bg); }
    .cs-view-btn.active { background: var(--gold); color: var(--text); border-color: var(--gold); }

    .cs-filter-bar { display: flex; gap: 4px; padding: 12px 16px; flex-wrap: wrap; align-items: center; }
    .cs-filter { padding: 4px 12px; border-radius: 16px; font-size: 12px; cursor: pointer; border: 1px solid var(--border); background: var(--white); color: var(--text-light); transition: all .15s; }
    .cs-filter:hover { background: var(--bg); }
    .cs-filter.active { background: var(--dark); color: var(--white); border-color: var(--text); }

    .cs-feed { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; padding: 16px; }
    .cs-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; cursor: pointer; transition: all .2s var(--ease-out); position: relative; box-shadow: var(--shadow-card); }
    .cs-card:hover { border-color: var(--gold); box-shadow: var(--shadow-elevated); transform: translateY(-2px); }
    .cs-card-status { position: absolute; top: 0; left: 0; right: 0; height: 3px; }
    .cs-card-status.draft { background: #9ca3af; }
    .cs-card-status.pending_review { background: #f59e0b; }
    .cs-card-status.approved { background: var(--success); }
    .cs-card-status.scheduled { background: var(--gold); }
    .cs-card-status.published { background: #a855f7; }
    .cs-card-status.rejected { background: #ef4444; }

    .cs-card-preview { aspect-ratio: 4/5; background: var(--bg); display: flex; align-items: center; justify-content: center; overflow: hidden; position: relative; }
    .cs-card-preview img { width: 100%; height: 100%; object-fit: cover; }
    .cs-card-preview .no-media { color: var(--text-light); font-size: 13px; text-align: center; padding: 20px; }
    .cs-card-body { padding: 12px; }
    .cs-card-caption { font-size: 13px; color: var(--text); line-height: 1.5; max-height: 60px; overflow: hidden; margin-bottom: 8px; white-space: pre-wrap; }
    .cs-card-meta { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
    .cs-card-platform { font-size: 10px; padding: 2px 7px; border-radius: 4px; background: var(--bg); color: var(--text-light); font-weight: 500; }
    .cs-card-date { font-size: 11px; color: var(--text-light); margin-left: auto; }
    .cs-card-actions { display: flex; gap: 4px; padding: 8px 12px; border-top: 1px solid var(--border); opacity: 0; transition: opacity .15s; }
    .cs-card:hover .cs-card-actions { opacity: 1; }
    .cs-card-actions button { padding: 4px 10px; font-size: 11px; border-radius: 6px; border: 1px solid var(--border); background: var(--white); cursor: pointer; transition: all .15s; }
    .cs-card-actions button:hover { background: var(--gold); border-color: var(--gold); color: var(--text); }
    .cs-card-format { position: absolute; top: 10px; right: 10px; font-size: 10px; padding: 2px 8px; border-radius: 10px; background: rgba(0,0,0,.6); color: #fff; font-weight: 500; }

    /* Content Studio — status badges (reused) */
    .post-status-badge { font-size: 11px; padding: 2px 8px; border-radius: 10px; font-weight: 500; }
    .post-status-badge.draft { background: #f3f4f6; color: #6b7280; }
    .post-status-badge.pending_review { background: #fef3c7; color: #92400e; }
    .post-status-badge.approved { background: #d1fae5; color: #065f46; }
    .post-status-badge.scheduled { background: rgba(226,189,35,0.1); color: #92400e; }
    .post-status-badge.published { background: #ede9fe; color: #5b21b6; }
    .post-status-badge.rejected { background: #fee2e2; color: #991b1b; }

    /* Content Studio — Calendar (kept) */
    .cc-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
    .cc-day-header { background: var(--bg); padding: 8px; text-align: center; font-size: 12px; font-weight: 600; color: var(--text-light); }
    .cc-day { background: var(--white); min-height: 80px; padding: 6px; cursor: pointer; transition: background .15s; position: relative; }
    .cc-day:hover { background: var(--surface-2); }
    .cc-day.other-month { background: var(--bg); opacity: .5; }
    .cc-day.today { background: var(--gold-light); }
    .cc-day-num { font-size: 12px; font-weight: 500; margin-bottom: 4px; }
    .cal-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin: 1px; cursor: pointer; }
    .cal-dot.draft { background: #9ca3af; }
    .cal-dot.pending_review { background: #f59e0b; }
    .cal-dot.approved { background: var(--success); }
    .cal-dot.scheduled { background: var(--gold); }
    .cal-dot.published { background: #a855f7; }
    .cal-dot.rejected { background: #ef4444; }

    /* Composer Overlay */
    .cs-composer-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 1000; display: flex; }
    .cs-composer { display: flex; width: 100%; height: 100%; background: var(--white); }
    .cs-composer-editor { flex: 1; overflow-y: auto; padding: 24px; border-right: 1px solid var(--border); }
    .cs-composer-preview { width: 420px; background: var(--bg); overflow-y: auto; padding: 24px; display: flex; flex-direction: column; align-items: center; }
    .cs-composer-close { position: absolute; top: 16px; right: 16px; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--border); background: var(--white); cursor: pointer; font-size: 18px; display: flex; align-items: center; justify-content: center; z-index: 1001; }
    .cs-composer-close:hover { background: var(--bg); }
    .cs-composer-overlay.hidden { display: none; }

    .cs-format-picker { display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 8px; margin-bottom: 20px; }
    .cs-format-card { padding: 10px 8px; border: 2px solid var(--border); border-radius: 10px; text-align: center; cursor: pointer; transition: all .15s; font-size: 12px; }
    .cs-format-card:hover { border-color: var(--gold); }
    .cs-format-card.selected { border-color: var(--gold); background: var(--surface-2); }
    .cs-format-card .icon { font-size: 20px; margin-bottom: 4px; }

    .cs-field { margin-bottom: 16px; }
    .cs-field label { font-size: 12px; font-weight: 600; display: block; margin-bottom: 4px; color: var(--text); }
    .cs-field textarea, .cs-field input, .cs-field select { width: 100%; padding: 10px 14px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; font-family: Barlow, sans-serif; box-sizing: border-box; outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .cs-field textarea:focus, .cs-field input:focus, .cs-field select:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }
    .cs-field textarea { resize: vertical; min-height: 120px; line-height: 1.6; }
    .cs-char-count { font-size: 11px; color: var(--text-light); text-align: right; margin-top: 2px; }

    .cs-hashtag-chips { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
    .cs-hashtag { font-size: 11px; padding: 3px 8px; border-radius: 12px; background: rgba(226,189,35,0.1); color: #92400e; cursor: pointer; }
    .cs-hashtag:hover { background: #fee2e2; color: #991b1b; text-decoration: line-through; }

    .cs-media-zone { border: 2px dashed var(--border); border-radius: 10px; padding: 16px; min-height: 80px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; cursor: pointer; transition: all .15s; }
    .cs-media-zone:hover { border-color: var(--gold); background: var(--surface-2); }
    .cs-media-thumb { width: 64px; height: 64px; border-radius: 8px; overflow: hidden; position: relative; border: 1px solid var(--border); }
    .cs-media-thumb img { width: 100%; height: 100%; object-fit: cover; }
    .cs-media-thumb .remove { position: absolute; top: 2px; right: 2px; width: 16px; height: 16px; border-radius: 50%; background: rgba(0,0,0,.6); color: #fff; font-size: 10px; display: flex; align-items: center; justify-content: center; cursor: pointer; }

    .cs-platform-toggles { display: flex; gap: 8px; }
    .cs-platform-toggle { display: flex; align-items: center; gap: 4px; font-size: 12px; cursor: pointer; padding: 6px 12px; border: 1px solid var(--border); border-radius: 8px; transition: all .15s; }
    .cs-platform-toggle.active { background: var(--dark); color: var(--white); border-color: var(--text); }

    .cs-schedule-row { display: flex; gap: 8px; align-items: center; }

    /* Phone Preview */
    .cs-phone-frame { width: 320px; background: #000; border-radius: 30px; padding: 12px; box-shadow: 0 8px 32px rgba(0,0,0,.2); }
    .cs-phone-screen { background: var(--white); border-radius: 20px; overflow: hidden; min-height: 480px; }
    .cs-phone-header { display: flex; align-items: center; gap: 8px; padding: 10px 12px; border-bottom: 1px solid var(--border); }
    .cs-phone-avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--gold); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; }
    .cs-phone-username { font-size: 12px; font-weight: 600; }
    .cs-phone-image { width: 100%; aspect-ratio: 4/5; background: var(--bg); display: flex; align-items: center; justify-content: center; overflow: hidden; }
    .cs-phone-image img { width: 100%; height: 100%; object-fit: cover; }
    .cs-phone-caption { padding: 10px 12px; font-size: 12px; line-height: 1.5; white-space: pre-wrap; }
    .cs-phone-caption .username { font-weight: 600; }
    .cs-phone-hashtags { color: var(--gold); }

    .cs-preview-toggle { display: flex; gap: 4px; margin-bottom: 12px; }
    .cs-preview-btn { padding: 4px 10px; border-radius: 12px; font-size: 11px; cursor: pointer; border: 1px solid var(--border); background: var(--white); transition: all .15s; }
    .cs-preview-btn.active { background: var(--dark); color: var(--white); border-color: var(--text); }

    /* Marketing AI Assist Panel */
    .cs-ai-panel { width: 380px; border-left: 1px solid var(--border); background: var(--white); display: flex; flex-direction: column; overflow: hidden; }
    .cs-ai-header { padding: 12px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 8px; }
    .cs-ai-prompts { display: flex; flex-wrap: wrap; gap: 6px; padding: 12px; }
    .cs-ai-prompt { padding: 6px 12px; border-radius: 16px; border: 1px solid var(--border); background: var(--white); cursor: pointer; font-size: 12px; transition: all .15s; }
    .cs-ai-prompt:hover { border-color: var(--gold); background: var(--surface-2); }
    .cs-ai-messages { flex: 1; overflow-y: auto; padding: 12px; }
    .cs-ai-msg { padding: 8px 12px; border-radius: 10px; margin-bottom: 8px; font-size: 13px; line-height: 1.5; white-space: pre-wrap; }
    .cs-ai-msg.user { background: var(--gold); color: var(--text); margin-left: 30px; }
    .cs-ai-msg.agent { background: var(--bg); margin-right: 30px; }
    .cs-ai-msg .use-btn { display: inline-block; margin-top: 6px; padding: 4px 12px; background: var(--gold); color: var(--text); border: none; border-radius: 6px; cursor: pointer; font-size: 11px; font-weight: 600; }
    .cs-ai-msg .use-btn:hover { background: #d4a920; }
    .cs-ai-input { display: flex; gap: 8px; padding: 12px; border-top: 1px solid var(--border); }
    .cs-ai-input input { flex: 1; padding: 8px 12px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; font-family: Barlow, sans-serif; outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .cs-ai-input input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    /* ── Creative Planner ─────────────────────────────────────────────────── */

    .cp-layout { display: flex; flex-direction: column; height: 100%; overflow: hidden; }
    .cp-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--border); background: var(--white); padding: 0 16px; flex-shrink: 0; }
    .cp-tab { padding: 10px 20px; font-size: 13px; font-weight: 600; border: none; background: none; cursor: pointer; color: var(--text-light); border-bottom: 2px solid transparent; transition: all .15s; }
    .cp-tab:hover { color: var(--text); }
    .cp-tab.active { color: var(--text); border-bottom-color: var(--gold); }
    .cp-body { flex: 1; overflow: hidden; }
    .cp-tab-divider { width: 1px; background: var(--border); margin: 6px 8px; align-self: stretch; }
    .cp-tab-tool { font-size: 12px; color: var(--text-light); }
    .cp-tab-tool.active { color: var(--text); border-bottom-color: var(--text-light); }

    /* Create view — split pane */
    .cp-create { display: flex; height: 100%; }
    .cp-chat { width: 55%; display: flex; flex-direction: column; border-right: 1px solid var(--border); }
    .cp-viewer { width: 45%; display: flex; flex-direction: column; overflow-y: auto; background: var(--bg); }

    /* Chat panel */
    .cp-messages { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 12px; }
    .cp-msg { max-width: 85%; padding: 10px 14px; border-radius: 12px; font-size: 13px; line-height: 1.6; white-space: pre-wrap; word-wrap: break-word; }
    .cp-msg.user { align-self: flex-end; background: var(--gold); color: var(--dark); border-bottom-right-radius: 4px; }
    .cp-msg.agent { align-self: flex-start; background: var(--white); border: 1px solid var(--border); border-bottom-left-radius: 4px; }
    .cp-msg.agent p { margin: 0 0 8px; }
    .cp-msg.agent ul, .cp-msg.agent ol { margin: 4px 0; padding-left: 20px; }
    .cp-action-result { margin-top: 8px; padding: 6px 10px; border-radius: 6px; font-size: 11px; background: rgba(107,167,59,.1); border: 1px solid rgba(107,167,59,.2); }
    .cp-action-error { background: rgba(239,68,68,.1); border-color: rgba(239,68,68,.2); }

    /* Welcome state */
    .cp-welcome { text-align: center; margin: auto; max-width: 360px; color: var(--text-light); }
    .cp-welcome-icon { font-size: 48px; margin-bottom: 12px; }
    .cp-welcome h3 { font-size: 18px; color: var(--text); margin-bottom: 8px; }
    .cp-welcome p { font-size: 13px; line-height: 1.6; margin-bottom: 16px; }

    /* Proactive suggestions */
    .cp-suggestions { display: flex; flex-direction: column; gap: 6px; max-width: 400px; margin: 0 auto; }
    .cp-suggestion { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: 10px; border: 1px solid var(--border); background: var(--white); cursor: pointer; text-align: left; font-size: 12px; transition: all .15s; }
    .cp-suggestion:hover { border-color: var(--gold); background: var(--surface-2); }
    .cp-suggestion-icon { font-size: 16px; flex-shrink: 0; }

    /* Quick chips */
    .cp-chips { display: flex; flex-wrap: wrap; gap: 6px; padding: 8px 16px; border-top: 1px solid var(--border); }
    .cp-chip { padding: 6px 12px; border-radius: 16px; border: 1px solid var(--border); background: var(--white); cursor: pointer; font-size: 11px; transition: all .15s; white-space: nowrap; }
    .cp-chip:hover { border-color: var(--gold); background: var(--surface-2); }

    /* Input bar */
    .cp-input-bar { display: flex; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border); background: var(--white); align-items: flex-end; }
    .cp-input { flex: 1; padding: 10px 14px; border: 1px solid var(--border); border-radius: 10px; font-size: 13px; font-family: Barlow, sans-serif; resize: none; outline: none; min-height: 40px; max-height: 120px; transition: border-color .2s; }
    .cp-input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }
    .cp-send { width: 40px; height: 40px; border-radius: 10px; border: none; background: var(--gold); color: var(--dark); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .15s; flex-shrink: 0; }
    .cp-send:hover { background: #d4a920; }
    .cp-send.sending { opacity: .5; cursor: not-allowed; }

    /* Viewer panel */
    .cp-viewer-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; text-align: center; padding: 40px; color: var(--text-light); }
    .cp-viewer-empty-icon { font-size: 48px; margin-bottom: 12px; opacity: .5; }
    .cp-viewer-empty h4 { font-size: 16px; color: var(--text); margin-bottom: 8px; }
    .cp-viewer-empty p { font-size: 12px; line-height: 1.6; margin-bottom: 16px; }
    .cp-viewer-tips { display: flex; flex-direction: column; gap: 6px; }
    .cp-viewer-tip { font-size: 11px; padding: 6px 12px; border-radius: 8px; background: var(--white); border: 1px solid var(--border); }
    .cp-loading { display: flex; align-items: center; justify-content: center; height: 100%; color: var(--text-light); font-size: 13px; }

    /* Ad preview */
    .cp-preview-wrap { padding: 20px; }
    .cp-preview-title { font-size: 14px; font-weight: 700; margin-bottom: 12px; }
    .cp-preview-toggle { display: flex; gap: 0; margin-bottom: 16px; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
    .cp-preview-btn { padding: 6px 14px; font-size: 11px; border: none; background: var(--white); cursor: pointer; font-weight: 600; }
    .cp-preview-btn.active { background: var(--gold); color: var(--dark); }
    .cp-preview-actions { display: flex; gap: 8px; margin-top: 16px; }

    /* Phone frame */
    .cp-phone-frame { width: 320px; margin: 0 auto; border: 2px solid #333; border-radius: 20px; overflow: hidden; background: #fff; box-shadow: 0 8px 32px rgba(0,0,0,.12); }
    .cp-phone-header { display: flex; align-items: center; gap: 8px; padding: 10px 12px; }
    .cp-phone-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--gold); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: var(--dark); }
    .cp-phone-name { font-size: 12px; font-weight: 700; }
    .cp-phone-sponsored { font-size: 10px; color: #888; }
    .cp-phone-image { height: 280px; background: var(--surface-2); display: flex; align-items: center; justify-content: center; }
    .cp-phone-image-placeholder { color: var(--text-light); font-size: 14px; }
    .cp-phone-cta-bar { display: flex; justify-content: space-between; align-items: center; padding: 10px 12px; border-top: 1px solid var(--border); }
    .cp-phone-link { font-size: 10px; color: #888; text-transform: uppercase; }
    .cp-phone-headline { font-size: 13px; font-weight: 700; margin-top: 2px; }
    .cp-phone-cta { padding: 6px 16px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 4px; font-size: 11px; font-weight: 600; cursor: default; }
    .cp-phone-body { padding: 10px 12px; font-size: 12px; line-height: 1.5; }

    /* Story preview */
    .cp-story-preview { height: 500px; background: linear-gradient(135deg, #1a1a2e, #2d2d4e); border-radius: 12px; display: flex; flex-direction: column; position: relative; overflow: hidden; }
    .cp-story-top { display: flex; align-items: center; gap: 6px; padding: 12px; }
    .cp-story-content { flex: 1; display: flex; flex-direction: column; justify-content: center; padding: 24px; text-align: center; }
    .cp-story-headline { font-size: 22px; font-weight: 800; color: #fff; margin-bottom: 12px; }
    .cp-story-body { font-size: 14px; color: rgba(255,255,255,.85); line-height: 1.5; }
    .cp-story-cta { text-align: center; padding: 12px; font-size: 13px; font-weight: 700; color: #fff; background: rgba(255,255,255,.15); border-top: 1px solid rgba(255,255,255,.1); }

    /* Campaign dashboard */
    .cp-campaign-dash { padding: 20px; }
    .cp-camp-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
    .cp-camp-name { font-size: 16px; font-weight: 700; }
    .cp-camp-status { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 10px; font-weight: 700; text-transform: uppercase; color: #fff; }
    .cp-camp-status.active { background: #6ba73b; }
    .cp-camp-status.paused { background: #888; }
    .cp-camp-budget { font-size: 13px; color: var(--text-light); margin-bottom: 16px; }
    .cp-kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 20px; }
    .cp-kpi { background: var(--white); border: 1px solid var(--border); border-radius: 8px; padding: 10px; text-align: center; }
    .cp-kpi-value { font-size: 16px; font-weight: 700; color: var(--text); }
    .cp-kpi-label { font-size: 10px; color: var(--text-light); margin-top: 2px; }
    .cp-adsets-title { font-size: 12px; font-weight: 700; text-transform: uppercase; color: var(--text-light); margin-bottom: 8px; letter-spacing: .5px; }
    .cp-adset-card { background: var(--white); border: 1px solid var(--border); border-radius: 8px; padding: 12px; margin-bottom: 8px; }
    .cp-adset-row { display: flex; align-items: center; justify-content: space-between; }
    .cp-adset-name { font-size: 13px; font-weight: 600; }
    .cp-adset-meta { font-size: 11px; color: var(--text-light); margin-top: 4px; }
    .cp-adset-actions { margin-top: 8px; display: flex; gap: 6px; }

    /* Calendar */
    .cp-calendar { padding: 20px; }
    .cp-calendar-empty { text-align: center; padding: 40px 20px; color: var(--text-light); font-size: 13px; }
    .cp-cal-item { background: var(--white); border: 1px solid var(--border); border-radius: 8px; padding: 12px; margin-bottom: 8px; cursor: pointer; transition: border-color .15s; }
    .cp-cal-item:hover { border-color: var(--gold); }
    .cp-cal-date { font-size: 11px; font-weight: 600; color: var(--gold); margin-bottom: 4px; }
    .cp-cal-text { font-size: 12px; line-height: 1.5; margin-bottom: 4px; }
    .cp-cal-meta { font-size: 10px; color: var(--text-light); }

    /* Confirmation */
    .cp-confirm { padding: 24px; }
    .cp-confirm h4 { font-size: 16px; margin-bottom: 12px; }
    .cp-confirm-details { margin: 12px 0; }
    .cp-confirm-details pre { font-size: 11px; background: var(--surface-2); padding: 12px; border-radius: 8px; overflow-x: auto; }
    .cp-confirm-actions { display: flex; gap: 8px; margin-top: 16px; }

    /* Live view */
    .cp-live { padding: 20px; overflow-y: auto; height: 100%; }
    .cp-live-section { margin-bottom: 24px; }
    .cp-live-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
    .cp-live-section h4 { font-size: 14px; font-weight: 700; margin-bottom: 12px; }
    .cp-live-empty { text-align: center; padding: 24px; color: var(--text-light); font-size: 12px; background: var(--white); border: 1px dashed var(--border); border-radius: 8px; }
    .cp-live-card { background: var(--white); border: 1px solid var(--border); border-radius: 8px; padding: 12px; margin-bottom: 8px; }
    .cp-live-card-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
    .cp-live-card-name { font-size: 13px; font-weight: 600; }
    .cp-live-card-date { font-size: 12px; font-weight: 600; }
    .cp-live-card-platforms { font-size: 11px; color: var(--text-light); }
    .cp-live-card-meta { font-size: 11px; color: var(--text-light); }
    .cp-live-card-preview { font-size: 12px; line-height: 1.5; margin: 4px 0; }
    .cp-live-card-actions { display: flex; gap: 6px; margin-top: 8px; }
    .cp-live-kpis { display: flex; gap: 12px; font-size: 11px; color: var(--text-light); margin: 4px 0; }

    /* Compact KPI grid for campaign cards */
    .cp-kpi-grid-compact { grid-template-columns: repeat(5, 1fr); gap: 6px; margin: 8px 0; }
    .cp-kpi-grid-compact .cp-kpi { padding: 6px 4px; }
    .cp-kpi-grid-compact .cp-kpi-value { font-size: 13px; }
    .cp-kpi-grid-compact .cp-kpi-label { font-size: 9px; }

    /* Collapse header for paused campaigns */
    .cp-live-collapse-header { display: flex; align-items: center; gap: 8px; cursor: pointer; padding: 8px 0; margin-bottom: 8px; user-select: none; }
    .cp-live-collapse-header:hover { opacity: .8; }
    .cp-live-collapse-header h4 { font-size: 14px; font-weight: 700; color: var(--text-light); }
    .cp-collapse-arrow { font-size: 10px; color: var(--text-light); width: 16px; }

    /* Ad set sub-items */
    .cp-adsets-sub { margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border); }
    .cp-adset-sub-item { display: flex; align-items: center; gap: 8px; padding: 4px 0; font-size: 12px; }
    .cp-adset-sub-item .cp-adset-name { flex: 1; }
    .cp-adset-sub-item .cp-adset-meta { color: var(--text-light); font-size: 11px; }

    /* Utility */
    .btn-gold { background: var(--gold) !important; color: var(--dark) !important; border-color: var(--gold) !important; }
    .btn-xs { padding: 3px 8px !important; font-size: 10px !important; }

    /* Media Drawer */
    .cs-media-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 360px; background: var(--white); border-left: 1px solid var(--border); box-shadow: -4px 0 16px rgba(0,0,0,.1); z-index: 1002; transform: translateX(100%); transition: transform .25s ease; overflow-y: auto; }
    .cs-media-drawer.open { transform: translateX(0); }
    .cs-media-drawer-header { padding: 16px; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; }
    .cs-media-drawer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; padding: 12px; }
    .cs-media-drawer-item { aspect-ratio: 1; border-radius: 6px; overflow: hidden; cursor: pointer; border: 2px solid transparent; transition: all .15s; }
    .cs-media-drawer-item:hover { border-color: var(--gold); }
    .cs-media-drawer-item img { width: 100%; height: 100%; object-fit: cover; }

    /* Campaigns */
    .cs-campaign-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; padding: 16px; }
    .cs-campaign-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 16px; cursor: pointer; transition: all .2s var(--ease-out); box-shadow: var(--shadow-card); }
    .cs-campaign-card:hover { border-color: var(--gold); }
    .cs-campaign-status { font-size: 11px; padding: 2px 8px; border-radius: 10px; font-weight: 500; }
    .cs-campaign-status.draft { background: #f3f4f6; color: #6b7280; }
    .cs-campaign-status.active { background: #d1fae5; color: #065f46; }
    .cs-campaign-status.paused { background: #fef3c7; color: #92400e; }
    .cs-campaign-status.completed { background: #ede9fe; color: #5b21b6; }


    /* ── Marketing Suite ─────────────────────────── */
    .mkt-layout { display: flex; height: calc(100% + 40px); margin: -20px -24px; }
    .mkt-subnav { width: 200px; background: var(--white); border-right: 1px solid var(--border); display: flex; flex-direction: column; flex-shrink: 0; overflow-y: auto; }
    .mkt-subnav-header { padding: 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
    .mkt-subnav-header .mkt-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, #8b5cf6, #7c3aed); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 12px; font-weight: 700; flex-shrink: 0; }
    .mkt-subnav-header .mkt-title { font-size: 14px; font-weight: 700; color: var(--text); line-height: 1.2; }
    .mkt-subnav-header .mkt-subtitle { font-size: 11px; color: var(--text-light); }
    .mkt-subnav-items { padding: 8px 0; flex: 1; }
    .mkt-subnav-item { display: flex; align-items: center; gap: 10px; padding: 10px 16px; cursor: pointer; font-size: 13px; font-weight: 500; color: var(--text-light); transition: all 0.15s; border-left: 3px solid transparent; }
    .mkt-subnav-item:hover { color: var(--text); background: var(--bg); }
    .mkt-subnav-item.active { color: #8b5cf6; background: rgba(139, 92, 246, 0.06); border-left-color: #8b5cf6; font-weight: 600; }
    .mkt-subnav-item svg { width: 16px; height: 16px; flex-shrink: 0; }
    .mkt-subnav-item .mkt-sub-badge { margin-left: auto; font-size: 10px; padding: 1px 6px; border-radius: 8px; background: var(--bg); color: var(--text-light); font-weight: 600; }
    .mkt-subnav-footer { padding: 12px 16px; border-top: 1px solid var(--border); }
    .mkt-max-btn { width: 100%; display: flex; align-items: center; gap: 8px; padding: 10px 12px; border-radius: 8px; border: 1px solid #8b5cf6; background: rgba(139, 92, 246, 0.06); cursor: pointer; font-family: Barlow, sans-serif; font-size: 12px; font-weight: 600; color: #8b5cf6; transition: all 0.15s; }
    .mkt-max-btn:hover { background: rgba(139, 92, 246, 0.12); }
    .mkt-body { flex: 1; overflow-y: auto; display: flex; flex-direction: column; }
    .mkt-body-header { padding: 16px 20px; background: var(--white); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
    .mkt-body-header h3 { margin: 0; font-size: 16px; font-weight: 700; color: var(--text); }
    .mkt-body-content { flex: 1; overflow-y: auto; padding: 20px; }
    .ad-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; margin-bottom: 20px; }
    .ad-stat-card { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 16px; text-align: center; transition: all 0.15s; }
    .ad-stat-card:hover { border-color: var(--gold); }
    .ad-stat-val { font-size: 24px; font-weight: 700; color: var(--text); }
    .ad-stat-label { font-size: 11px; color: var(--text-light); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px; }
    .ad-stat-change { font-size: 11px; margin-top: 4px; font-weight: 600; }
    .ad-stat-change.up { color: var(--success); }
    .ad-stat-change.down { color: #ef4444; }
    .ad-campaign-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; }
    .ad-campaign-card { background: var(--white); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; transition: all 0.15s; cursor: pointer; }
    .ad-campaign-card:hover { border-color: var(--gold); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
    .ad-campaign-top { padding: 16px; }
    .ad-campaign-creative { aspect-ratio: 16/9; background: var(--bg); display: flex; align-items: center; justify-content: center; overflow: hidden; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .ad-campaign-creative img { width: 100%; height: 100%; object-fit: cover; }
    .ad-campaign-metrics { display: grid; grid-template-columns: repeat(4, 1fr); padding: 12px 16px; gap: 8px; background: var(--bg); }
    .ad-metric { text-align: center; }
    .ad-metric-val { font-size: 14px; font-weight: 700; color: var(--text); }
    .ad-metric-label { font-size: 10px; color: var(--text-light); text-transform: uppercase; }
    .ad-builder { background: var(--white); border: 1px solid var(--border); border-radius: 12px; padding: 20px; margin-top: 20px; }
    .ad-builder h4 { margin: 0 0 16px; font-size: 15px; font-weight: 700; }
    .ad-field { margin-bottom: 14px; }
    .ad-field label { font-size: 12px; font-weight: 600; display: block; margin-bottom: 4px; color: var(--text-light); text-transform: uppercase; letter-spacing: 0.3px; }
    .ad-field input, .ad-field select, .ad-field textarea { width: 100%; padding: 10px 14px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; font-family: Barlow, sans-serif; box-sizing: border-box; outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .ad-field input:focus, .ad-field select:focus, .ad-field textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }
    .ad-field textarea { resize: vertical; min-height: 80px; }
    .ad-abtest { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 16px; }
    .ad-abtest-card { background: var(--bg); border: 1px solid var(--border); border-radius: 10px; padding: 14px; position: relative; }
    .ad-abtest-label { position: absolute; top: -8px; left: 12px; background: var(--white); padding: 0 8px; font-size: 11px; font-weight: 700; color: var(--text-light); }
    .social-platforms { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; margin-bottom: 20px; }
    .social-platform-card { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 16px; display: flex; align-items: center; gap: 12px; transition: all 0.15s; }
    .social-platform-card:hover { border-color: var(--gold); }
    .social-platform-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; color: #fff; flex-shrink: 0; }
    .social-platform-icon.ig { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
    .social-platform-icon.fb { background: var(--dusk); }
    .social-platform-icon.wa { background: #25d366; }
    .social-platform-info { flex: 1; }
    .social-platform-name { font-weight: 600; font-size: 14px; color: var(--text); }
    .social-platform-stat { font-size: 12px; color: var(--text-light); }
    .social-connected { font-size: 11px; padding: 3px 8px; border-radius: 10px; font-weight: 600; }
    .social-connected.yes { background: #d1fae5; color: #065f46; }
    .social-connected.no { background: #fee2e2; color: #991b1b; }
    .social-metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin-bottom: 20px; }
    .social-metric-card { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 14px; text-align: center; }
    .social-metric-val { font-size: 22px; font-weight: 700; color: var(--text); }
    .social-metric-label { font-size: 11px; color: var(--text-light); margin-top: 2px; }
    .social-section { background: var(--white); border: 1px solid var(--border); border-radius: 12px; padding: 16px; margin-bottom: 16px; }
    .social-section h4 { margin: 0 0 12px; font-size: 14px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; }
    .social-rule { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--border); }
    .social-rule:last-child { border-bottom: none; }
    .social-rule-info { flex: 1; }
    .social-rule-name { font-size: 13px; font-weight: 600; color: var(--text); }
    .social-rule-desc { font-size: 12px; color: var(--text-light); margin-top: 2px; }
    .social-template { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border); align-items: flex-start; }
    .social-template:last-child { border-bottom: none; }
    .social-template-trigger { font-size: 11px; padding: 3px 8px; border-radius: 6px; background: rgba(226,189,35,0.1); color: #92400e; font-weight: 600; flex-shrink: 0; }
    .social-template-body { font-size: 13px; color: var(--text); line-height: 1.4; flex: 1; }
    .social-cal-week { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
    .social-cal-day { background: var(--white); min-height: 100px; padding: 8px; cursor: pointer; transition: background 0.15s; }
    .social-cal-day:hover { background: var(--surface-2); }
    .social-cal-day.today { background: var(--gold-light); }
    .social-cal-day-header { font-size: 11px; color: var(--text-light); font-weight: 600; margin-bottom: 4px; }
    .social-cal-day-num { font-size: 13px; font-weight: 700; color: var(--text); }
    .social-cal-post { margin-top: 4px; padding: 3px 6px; border-radius: 4px; font-size: 10px; font-weight: 500; cursor: pointer; }
    .social-cal-post.ig { background: #fce4ec; color: #c62828; }
    .social-cal-post.fb { background: rgba(74,111,165,0.12); color: var(--dusk); }
    .media-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; }
    .media-item { background: var(--white); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; cursor: pointer; transition: all 0.15s; position: relative; }
    .media-item:hover { border-color: var(--gold); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
    .media-item-preview { aspect-ratio: 1; background: var(--bg); overflow: hidden; display: flex; align-items: center; justify-content: center; }
    .media-item-preview img { width: 100%; height: 100%; object-fit: cover; }
    .media-item-preview video { width: 100%; height: 100%; object-fit: cover; }
    .media-item-info { padding: 8px 10px; }
    .media-item-name { font-size: 12px; font-weight: 500; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .media-item-meta { font-size: 10px; color: var(--text-light); margin-top: 2px; display: flex; justify-content: space-between; }
    .media-item-actions { position: absolute; top: 8px; right: 8px; display: flex; gap: 4px; opacity: 0; transition: opacity 0.15s; }
    .media-item:hover .media-item-actions { opacity: 1; }
    .media-item-actions button { width: 28px; height: 28px; border-radius: 6px; border: none; background: rgba(0,0,0,0.6); color: #fff; cursor: pointer; font-size: 12px; display: flex; align-items: center; justify-content: center; }
    .media-item-actions button:hover { background: rgba(0,0,0,0.8); }
    .media-item-tags { display: flex; flex-wrap: wrap; gap: 2px; padding: 0 10px 8px; }
    .media-tag { font-size: 9px; padding: 1px 6px; border-radius: 8px; background: #edf2f7; color: #4a5568; }
    .media-upload-zone { border: 2px dashed var(--border); border-radius: 12px; padding: 40px 20px; text-align: center; cursor: pointer; transition: all 0.15s; margin-bottom: 20px; }
    .media-upload-zone:hover { border-color: var(--gold); background: var(--surface-2); }
    .media-upload-icon { font-size: 36px; margin-bottom: 8px; }
    .media-upload-text { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
    .media-upload-hint { font-size: 12px; color: var(--text-light); }
    .media-detail-panel { position: fixed; right: 0; top: 0; bottom: 0; width: 340px; background: var(--white); border-left: 1px solid var(--border); box-shadow: -4px 0 16px rgba(0,0,0,0.08); z-index: 800; transform: translateX(100%); transition: transform 0.25s ease; overflow-y: auto; padding: 16px; }
    .media-detail-panel.open { transform: translateX(0); }
    .media-detail-preview { width: 100%; aspect-ratio: 1; border-radius: 8px; overflow: hidden; margin-bottom: 12px; background: var(--bg); }
    .media-detail-preview img, .media-detail-preview video { width: 100%; height: 100%; object-fit: cover; }
    .media-detail-field { margin-bottom: 12px; }
    .media-detail-field label { font-size: 11px; font-weight: 600; text-transform: uppercase; color: var(--text-light); display: block; margin-bottom: 3px; }
    .media-detail-field .val { font-size: 13px; color: var(--text); }
    .max-float-panel { position: fixed; right: 0; top: 0; bottom: 0; width: 380px; background: var(--white); border-left: 1px solid var(--border); box-shadow: -4px 0 20px rgba(0,0,0,0.08); z-index: 900; transform: translateX(100%); transition: transform 0.25s ease; display: flex; flex-direction: column; }
    .max-float-panel.open { transform: translateX(0); }
    .max-float-header { padding: 14px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
    .max-float-header .max-av { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, #8b5cf6, #7c3aed); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 12px; font-weight: 700; }
    .max-float-header .max-name { font-weight: 700; font-size: 14px; color: var(--text); }
    .max-float-header .max-role { font-size: 11px; color: var(--text-light); }
    .max-float-close { margin-left: auto; background: none; border: none; font-size: 20px; cursor: pointer; color: var(--text-light); padding: 4px; }
    .max-float-close:hover { color: var(--text); }
    .max-float-prompts { display: flex; flex-wrap: wrap; gap: 6px; padding: 12px 16px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
    .max-float-prompt { padding: 5px 12px; border-radius: 16px; border: 1px solid var(--border); background: var(--white); cursor: pointer; font-size: 11px; font-weight: 500; transition: all 0.15s; font-family: Barlow, sans-serif; }
    .max-float-prompt:hover { border-color: #8b5cf6; background: rgba(139,92,246,0.06); color: #8b5cf6; }
    .max-float-messages { flex: 1; overflow-y: auto; padding: 16px; }
    .max-float-msg { padding: 10px 14px; border-radius: 12px; margin-bottom: 8px; font-size: 13px; line-height: 1.5; white-space: pre-wrap; }
    .max-float-msg.user { background: #8b5cf6; color: #fff; margin-left: 40px; border-bottom-right-radius: 4px; }
    .max-float-msg.agent { background: var(--bg); color: var(--text); margin-right: 40px; border-bottom-left-radius: 4px; }
    .max-float-msg .max-use-btn { display: inline-block; margin-top: 6px; padding: 4px 12px; background: #8b5cf6; color: #fff; border: none; border-radius: 6px; cursor: pointer; font-size: 11px; font-weight: 600; }
    .max-float-msg .max-use-btn:hover { background: #7c3aed; }
    .max-float-input { display: flex; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border); flex-shrink: 0; }
    .max-float-input input { flex: 1; padding: 10px 14px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; font-family: Barlow, sans-serif; outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .max-float-input input:focus { border-color: #8b5cf6; box-shadow: 0 0 0 3px rgba(139,92,246,0.2); }
    .max-float-input button { padding: 8px 16px; border-radius: 8px; border: none; background: #8b5cf6; color: #fff; cursor: pointer; font-family: Barlow, sans-serif; font-size: 13px; font-weight: 600; }
    .max-float-input button:hover { background: #7c3aed; }

    /* ── Enhanced Marketing Suite v2 ─────────── */
    .mkt-section { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 20px; margin-bottom: 16px; }
    .mkt-section h4 { margin: 0 0 16px; font-size: 14px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; }
    .mkt-section h4 svg { width: 16px; height: 16px; flex-shrink: 0; }
    .mkt-kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; margin-bottom: 20px; }
    .mkt-kpi { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 16px; text-align: center; transition: all 0.15s; }
    .mkt-kpi:hover { border-color: #8b5cf6; }
    .mkt-kpi-val { font-size: 22px; font-weight: 700; color: var(--text); }
    .mkt-kpi-label { font-size: 11px; color: var(--text-light); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px; }
    .mkt-kpi-sub { font-size: 10px; color: var(--text-dim); margin-top: 4px; }
    .mkt-tab-bar { display: flex; gap: 4px; margin-bottom: 16px; }
    .mkt-tab { padding: 6px 16px; border-radius: 20px; font-size: 12px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--white); color: var(--text); transition: all 0.15s; font-family: Barlow, sans-serif; }
    .mkt-tab:hover { background: var(--bg); }
    .mkt-tab.active { background: #8b5cf6; color: #fff; border-color: #8b5cf6; }
    .mkt-empty { text-align: center; padding: 40px 20px; }
    .mkt-empty-icon { font-size: 40px; margin-bottom: 12px; color: var(--text-dim); }
    .mkt-empty-title { font-size: 16px; font-weight: 600; margin-bottom: 8px; color: var(--text); }
    .mkt-empty-desc { font-size: 13px; color: var(--text-light); margin-bottom: 16px; }

    /* Content Calendar enhanced */
    .cc-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
    .cc-nav { display: flex; align-items: center; gap: 8px; }
    .cc-nav-btn { width: 32px; height: 32px; border-radius: 6px; border: 1px solid var(--border); background: var(--white); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 14px; transition: all 0.15s; }
    .cc-nav-btn:hover { border-color: #8b5cf6; color: #8b5cf6; }
    .cc-month-label { font-weight: 700; font-size: 16px; color: var(--text); min-width: 180px; text-align: center; }
    .cc-view-modes { display: flex; gap: 4px; }
    .cc-mode { padding: 5px 12px; border-radius: 6px; font-size: 11px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--white); color: var(--text-light); transition: all 0.15s; font-family: Barlow, sans-serif; }
    .cc-mode.active { background: #8b5cf6; color: #fff; border-color: #8b5cf6; }
    .cc-week-grid { display: grid; grid-template-columns: 60px repeat(7, 1fr); gap: 0; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
    .cc-week-header { background: var(--bg); padding: 10px 8px; font-size: 11px; font-weight: 600; color: var(--text-light); text-align: center; border-bottom: 1px solid var(--border); }
    .cc-week-header.today-col { color: #8b5cf6; }
    .cc-time-slot { padding: 4px 8px; font-size: 10px; color: var(--text-dim); text-align: right; border-right: 1px solid var(--border); min-height: 50px; display: flex; align-items: flex-start; justify-content: flex-end; }
    .cc-week-cell { min-height: 50px; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 2px; position: relative; cursor: pointer; transition: background 0.15s; }
    .cc-week-cell:last-child { border-right: none; }
    .cc-week-cell:hover { background: rgba(139, 92, 246, 0.04); }
    .cc-week-event { padding: 3px 6px; border-radius: 4px; font-size: 10px; font-weight: 500; margin-bottom: 2px; cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .cc-week-event.ig { background: #fce4ec; color: #c62828; border-left: 3px solid #e91e63; }
    .cc-week-event.fb { background: rgba(74,111,165,0.12); color: var(--dusk); border-left: 3px solid var(--dusk); }
    .cc-week-event.story { background: rgba(139,92,246,0.12); color: #7c3aed; border-left: 3px solid #8b5cf6; }

    /* Content item modal */
    .mkt-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 1100; display: flex; align-items: center; justify-content: center; animation: fadeIn 0.15s; }
    .mkt-modal { background: var(--white); border-radius: 12px; width: 560px; max-width: 95vw; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.15); }
    .mkt-modal-header { padding: 16px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
    .mkt-modal-header h3 { margin: 0; font-size: 16px; font-weight: 700; }
    .mkt-modal-body { padding: 20px; }
    .mkt-modal-footer { padding: 12px 20px; border-top: 1px solid var(--border); display: flex; gap: 8px; justify-content: flex-end; }
    .mkt-form-group { margin-bottom: 16px; }
    .mkt-form-group label { font-size: 12px; font-weight: 600; display: block; margin-bottom: 4px; color: var(--text-light); text-transform: uppercase; letter-spacing: 0.3px; }
    .mkt-form-group input, .mkt-form-group select, .mkt-form-group textarea { width: 100%; padding: 10px 14px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; font-family: Barlow, sans-serif; box-sizing: border-box; outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .mkt-form-group input:focus, .mkt-form-group select:focus, .mkt-form-group textarea:focus { border-color: #8b5cf6; box-shadow: 0 0 0 3px rgba(139,92,246,0.15); }
    .mkt-form-group textarea { resize: vertical; min-height: 80px; }
    .mkt-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

    /* Content ideas */
    .mkt-idea-card { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; margin-bottom: 8px; cursor: pointer; transition: all 0.15s; }
    .mkt-idea-card:hover { border-color: #8b5cf6; background: rgba(139,92,246,0.04); }
    .mkt-idea-title { font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
    .mkt-idea-meta { font-size: 11px; color: var(--text-light); display: flex; gap: 8px; align-items: center; }
    .mkt-idea-type { font-size: 10px; padding: 2px 8px; border-radius: 10px; font-weight: 600; }
    .mkt-idea-type.ig { background: #fce4ec; color: #c62828; }
    .mkt-idea-type.fb { background: rgba(74,111,165,0.12); color: var(--dusk); }
    .mkt-idea-type.story { background: rgba(139,92,246,0.12); color: #7c3aed; }
    .mkt-idea-type.carousel { background: rgba(226,189,35,0.12); color: #92400e; }
    .mkt-idea-type.video { background: rgba(239,68,68,0.1); color: #dc2626; }

    /* Campaign manager enhanced */
    .camp-card { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 16px; transition: all 0.15s; cursor: pointer; }
    .camp-card:hover { border-color: #8b5cf6; box-shadow: 0 4px 12px rgba(0,0,0,0.06); transform: translateY(-1px); }
    .camp-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 10px; }
    .camp-name { font-weight: 700; font-size: 15px; color: var(--text); }
    .camp-status { font-size: 10px; font-weight: 700; padding: 3px 10px; border-radius: 4px; text-transform: uppercase; }
    .camp-status.draft { background: #f3f4f6; color: #6b7280; }
    .camp-status.active { background: #d1fae5; color: #065f46; }
    .camp-status.paused { background: #fef3c7; color: #92400e; }
    .camp-status.completed { background: rgba(74,111,165,0.12); color: var(--dusk); }
    .camp-meta { font-size: 12px; color: var(--text-light); margin-bottom: 12px; }
    .camp-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; padding-top: 12px; border-top: 1px solid var(--border); }
    .camp-metric { text-align: center; }
    .camp-metric-val { font-size: 14px; font-weight: 700; color: var(--text); }
    .camp-metric-label { font-size: 10px; color: var(--text-light); text-transform: uppercase; }
    .camp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
    .camp-budget-bar { height: 4px; background: var(--border); border-radius: 2px; margin-top: 8px; overflow: hidden; }
    .camp-budget-fill { height: 100%; border-radius: 2px; transition: width 0.3s; }

    /* A/B Test */
    .ab-container { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 16px; }
    .ab-variant { background: var(--bg); border: 1px solid var(--border); border-radius: 10px; padding: 16px; position: relative; }
    .ab-variant-label { position: absolute; top: -8px; left: 12px; background: var(--white); padding: 0 8px; font-size: 11px; font-weight: 700; color: var(--text-light); }
    .ab-winner { border-color: var(--success); background: rgba(107,167,59,0.04); }
    .ab-winner .ab-variant-label { color: var(--success); }

    /* Budget recommendation */
    .budget-rec { background: rgba(139,92,246,0.06); border: 1px solid rgba(139,92,246,0.2); border-radius: 10px; padding: 16px; margin-top: 16px; }
    .budget-rec-title { font-size: 13px; font-weight: 600; color: #8b5cf6; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
    .budget-rec-item { font-size: 12px; color: var(--text); padding: 6px 0; border-bottom: 1px solid rgba(139,92,246,0.1); display: flex; justify-content: space-between; }
    .budget-rec-item:last-child { border-bottom: none; }

    /* Social enhanced */
    .social-scheduler { display: grid; grid-template-columns: 80px repeat(7, 1fr); gap: 0; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; margin-bottom: 16px; }
    .social-sched-header { background: var(--bg); padding: 10px 4px; font-size: 11px; font-weight: 600; color: var(--text-light); text-align: center; border-bottom: 1px solid var(--border); }
    .social-sched-time { padding: 8px 6px; font-size: 10px; color: var(--text-dim); text-align: right; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .social-sched-cell { border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 2px; min-height: 36px; cursor: pointer; transition: background 0.15s; }
    .social-sched-cell:hover { background: rgba(139,92,246,0.04); }
    .social-sched-event { padding: 2px 5px; border-radius: 3px; font-size: 9px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 1px; }

    .hashtag-group { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px; margin-bottom: 8px; }
    .hashtag-group-title { font-size: 12px; font-weight: 600; color: var(--text); margin-bottom: 6px; }
    .hashtag-chips { display: flex; flex-wrap: wrap; gap: 4px; }
    .hashtag-chip { font-size: 11px; padding: 3px 10px; border-radius: 12px; background: rgba(139,92,246,0.1); color: #7c3aed; cursor: pointer; transition: all 0.15s; font-weight: 500; }
    .hashtag-chip:hover { background: rgba(139,92,246,0.2); }
    .best-time-slot { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border); }
    .best-time-slot:last-child { border-bottom: none; }
    .best-time-bar { flex: 1; height: 8px; background: var(--border); border-radius: 4px; overflow: hidden; }
    .best-time-fill { height: 100%; border-radius: 4px; }
    .best-time-label { font-size: 12px; font-weight: 500; color: var(--text); min-width: 60px; }
    .best-time-val { font-size: 11px; color: var(--text-light); min-width: 40px; text-align: right; }

    /* Script generator */
    .script-templates { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
    .script-template-card { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 16px; cursor: pointer; transition: all 0.15s; }
    .script-template-card:hover { border-color: #8b5cf6; box-shadow: 0 4px 12px rgba(0,0,0,0.06); transform: translateY(-1px); }
    .script-template-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; margin-bottom: 10px; }
    .script-template-name { font-weight: 600; font-size: 14px; color: var(--text); margin-bottom: 4px; }
    .script-template-desc { font-size: 12px; color: var(--text-light); line-height: 1.4; }
    .script-output { background: var(--bg); border: 1px solid var(--border); border-radius: 10px; padding: 16px; margin-top: 16px; white-space: pre-wrap; font-size: 13px; line-height: 1.6; color: var(--text); max-height: 400px; overflow-y: auto; }
    .tone-chip { padding: 5px 14px; border-radius: 20px; font-size: 12px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--white); color: var(--text); transition: all 0.15s; font-family: Barlow, sans-serif; }
    .tone-chip:hover { background: var(--bg); }
    .tone-chip.active { background: #8b5cf6; color: #fff; border-color: #8b5cf6; }

    /* ── Automations ──────────────────────────── */
    .auto-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; padding: 16px; }
    .auto-stat { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 14px; text-align: center; box-shadow: var(--shadow-card); }
    .auto-stat-val { font-size: 22px; font-weight: 700; color: var(--text); }
    .auto-stat-label { font-size: 11px; color: var(--text-light); margin-top: 2px; }

    .auto-tabs { display: flex; gap: 4px; padding: 12px 16px; border-bottom: 1px solid var(--border); }
    .auto-tab { padding: 6px 14px; border-radius: 20px; font-size: 13px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--white); color: var(--text); transition: all .15s; }
    .auto-tab:hover { background: var(--bg); }
    .auto-tab.active { background: var(--gold); color: var(--text); border-color: var(--gold); }

    .auto-cards { display: flex; flex-direction: column; gap: 10px; padding: 16px; }
    .auto-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 16px; transition: all .2s var(--ease-out); box-shadow: var(--shadow-card); }
    .auto-card:hover { border-color: var(--gold); transform: translateY(-1px); box-shadow: var(--shadow-elevated); }
    .auto-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
    .auto-card-title { font-weight: 600; font-size: 14px; display: flex; align-items: center; gap: 8px; }
    .auto-card-desc { font-size: 13px; color: var(--text-light); margin-bottom: 10px; }
    .auto-card-flow { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }
    .auto-chip { font-size: 11px; padding: 3px 10px; border-radius: 12px; font-weight: 500; }
    .auto-chip.trigger { background: rgba(226,189,35,0.15); color: #92400e; }
    .auto-chip.condition { background: var(--dusk-light); color: var(--dusk); }
    .auto-chip.action { background: #d1fae5; color: #065f46; }
    .auto-chip.mode-template { background: #f3f4f6; color: #374151; }
    .auto-chip.mode-ai { background: #ede9fe; color: #5b21b6; }
    .auto-arrow { color: var(--text-light); font-size: 14px; }
    .auto-card-footer { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--text-light); }
    .auto-toggle { position: relative; width: 36px; height: 20px; cursor: pointer; }
    .auto-toggle input { display: none; }
    .auto-toggle-slider { position: absolute; inset: 0; background: #d1d5db; border-radius: 20px; transition: .2s; }
    .auto-toggle-slider:before { content: ''; position: absolute; width: 16px; height: 16px; left: 2px; bottom: 2px; background: var(--surface-1); border-radius: 50%; transition: .2s; }
    .auto-toggle input:checked + .auto-toggle-slider { background: var(--gold); }
    .auto-toggle input:checked + .auto-toggle-slider:before { transform: translateX(16px); }

    .auto-log-table { width: 100%; border-collapse: collapse; font-size: 13px; }
    .auto-log-table th { text-align: left; padding: 8px 12px; background: var(--bg); font-weight: 600; font-size: 12px; color: var(--text-light); border-bottom: 1px solid var(--border); }
    .auto-log-table td { padding: 8px 12px; border-bottom: 1px solid var(--border); }
    .log-status { font-size: 11px; padding: 2px 8px; border-radius: 10px; font-weight: 500; }
    .log-status.success { background: #d1fae5; color: #065f46; }
    .log-status.skipped { background: #f3f4f6; color: #6b7280; }
    .log-status.error { background: #fee2e2; color: #991b1b; }

    /* Channel badges */
    .ch-badge { display: inline-flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 600; padding: 1px 5px; border-radius: 3px; color: #fff; margin-left: 4px; text-transform: uppercase; letter-spacing: 0.5px; }
    .ch-badge.whatsapp { background: #25d366; }
    .ch-badge.sms { background: #4a6fa5; }
    .ch-badge.instagram { background: #E1306C; }
    .ch-badge.messenger { background: #0084FF; }
    .ch-badge.email { background: #718096; }

    .ch-filter-bar { display: flex; gap: 4px; padding: 8px 12px; flex-wrap: wrap; }
    .ch-filter { padding: 4px 10px; border-radius: 12px; font-size: 11px; font-weight: 500; cursor: pointer; border: 1px solid var(--border); background: var(--white); color: var(--text); transition: all .15s; }
    .ch-filter:hover { background: var(--bg); }
    .ch-filter.active { background: var(--gold); color: var(--text); border-color: var(--gold); }

    .ch-selector { display: flex; align-items: center; gap: 6px; }
    .ch-selector select { padding: 6px 10px; border: 1px solid var(--border); border-radius: 6px; font-size: 12px; font-family: Barlow, sans-serif; background: var(--white); outline: none; transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out); }
    .ch-selector select:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--accent-glow); }

    /* Channel message indicator */
    .msg-channel { display: inline-block; font-size: 9px; color: var(--text-light); margin-left: 6px; text-transform: uppercase; letter-spacing: 0.5px; }

    /* ── Mobile PWA Experience ──────────────────── */

    /* Mobile bottom nav */
    .mobile-tabs { display: none; }
    .mobile-menu-btn { display: none; }

    @media (max-width: 768px) {
      /* Hide sidebar completely, show via More tap */
      .sidebar { display: none !important; }
      .sidebar.mobile-open {
        display: flex !important; position: fixed; left: 0; top: 0; bottom: 0;
        z-index: 200; width: 260px; box-shadow: 4px 0 24px rgba(0,0,0,0.3);
      }

      .main { margin-left: 0 !important; padding-bottom: 60px; width: 100vw; max-width: 100vw; overflow-x: hidden; }
      html, body { max-width: 100vw; overflow-x: hidden; }

      /* Bottom tab bar */
      .mobile-tabs {
        display: flex !important;
        position: fixed; bottom: 0; left: 0; right: 0;
        background: var(--white); border-top: 1px solid var(--border);
        z-index: 100; height: 56px; align-items: stretch;
        padding-bottom: env(safe-area-inset-bottom, 0px);
        box-shadow: 0 -2px 10px rgba(0,0,0,0.05);
      }
      .mobile-tab {
        flex: 1; display: flex; flex-direction: column; align-items: center;
        justify-content: center; padding: 4px 0; cursor: pointer;
        color: var(--dusk); font-size: 10px; font-weight: 500;
        gap: 2px; text-decoration: none; min-height: 44px;
        transition: color 0.15s;
        -webkit-tap-highlight-color: transparent;
      }
      .mobile-tab.active { color: var(--gold); font-weight: 600; }
      .mobile-tab svg { width: 22px; height: 22px; }

      .topbar { padding: 8px 12px !important; }
      .topbar h2 { font-size: 16px !important; }
      .ai-search-wrap { display: none !important; }
      .topbar .notif-btn { min-width: 44px; min-height: 44px; }

      .mobile-menu-btn {
        display: flex !important;
        width: 36px; height: 36px; align-items: center; justify-content: center;
        background: none; border: 1px solid var(--border); border-radius: 6px;
        cursor: pointer; font-size: 18px; color: var(--text);
        min-width: 44px; min-height: 44px;
      }

      /* Content cards responsive */
      .cs-feed { grid-template-columns: 1fr !important; }
      .post-cards { grid-template-columns: 1fr !important; }
      .proj-board { flex-direction: column !important; }
      .proj-col { min-width: 100% !important; }

      /* Composer mobile */
      .cs-composer { flex-direction: column !important; }
      .cs-composer-editor { border-right: none !important; border-bottom: 1px solid var(--border); max-height: 60vh; }
      .cs-composer-preview { width: 100% !important; }
      .cs-phone-frame { width: 260px !important; }

      /* Pipeline kanban scroll */
      .pipeline-board { overflow-x: auto; }

      /* Contact detail panel full-screen on mobile */
      .contact-detail-panel { width: 100% !important; position: fixed !important; inset: 0 !important; bottom: 60px !important; z-index: 99; }

      /* Mobile conversation detail header */
      .conv-detail-header { padding: 10px 12px !important; }

      /* Mobile message compose - fixed to bottom above tab bar */
      .conv-detail .conv-input {
        padding: 8px 10px;
        padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
      }

      /* Contact card full-screen on mobile */
      .contact-card-overlay { align-items: stretch !important; justify-content: stretch !important; padding: 0 !important; }
      .contact-card {
        width: 100% !important; max-width: 100% !important; max-height: 100% !important;
        border-radius: 0 !important; height: 100%;
      }
      .contact-card-body { flex-direction: column !important; }
      .contact-card-left { width: 100% !important; border-right: none !important; border-bottom: 1px solid var(--border); max-height: 40vh; }
      .contact-card-right { width: 100% !important; }

      /* Modals full-screen on mobile */
      .modal-overlay { align-items: stretch !important; padding: 0 !important; }
      .modal { width: 100% !important; max-width: 100% !important; border-radius: 0 !important; max-height: 100vh !important; overflow-y: auto; }

      /* Prevent iOS zoom on inputs */
      input, select, textarea { font-size: 16px !important; }
      .conv-input input, .conv-input textarea { font-size: 16px !important; }

      /* All tap targets min 44px */
      .btn, .nav-item, .list-item, .conv-filter-btn, .pipeline-card .card-action-btn,
      .contact-card-tab, .settings-tab, .proj-tab {
        min-height: 44px;
      }

      /* Marketing suite responsive */
      .mkt-layout { flex-direction: column !important; }
      .mkt-subnav { width: 100% !important; max-height: 50px; overflow: hidden; flex-direction: row !important; }
      .mkt-subnav.mobile-expanded { max-height: none; flex-direction: column !important; }
      .mkt-subnav-items { display: flex; overflow-x: auto; padding: 0 !important; }
      .mkt-subnav-item { white-space: nowrap; padding: 8px 12px !important; border-left: none !important; }
      .mkt-subnav-header { display: none !important; }
      .mkt-subnav-footer { display: none !important; }
    }

    /* Touch device: replace hover with active */
    @media (hover: none) {
      .card-hover:hover { transform: none; box-shadow: var(--shadow-card); }
      .card-hover:active { transform: translateY(-1px); box-shadow: var(--shadow-elevated); }
      .list-item:hover { background: none; }
      .list-item:active { background: var(--bg); }
      .nav-item:hover { background: none; }
      .nav-item:active { background: rgba(255,255,255,0.05); }
      .btn-primary:hover { background: var(--gold); }
      .btn-primary:active { background: var(--accent-hover); }
      .btn-ghost:hover { background: transparent; }
      .btn-ghost:active { background: var(--bg); }
      .pipeline-card .card-action-btn:hover { border-color: var(--border); color: var(--text-light); background: var(--bg); }
      .pipeline-card .card-action-btn:active { border-color: var(--gold); color: var(--text); background: var(--gold-light); }
      .dash-quick-btn:hover { border-color: var(--border); background: var(--surface-1); transform: none; box-shadow: none; }
      .dash-quick-btn:active { border-color: var(--gold); background: rgba(226,189,35,0.04); }
      .cs-card:hover { border-color: var(--border); box-shadow: var(--shadow-card); transform: none; }
      .cs-card:active { border-color: var(--gold); box-shadow: var(--shadow-elevated); }
      .cs-card:hover .cs-card-actions { opacity: 1; }
    }

    /* ── Pull-to-Refresh ─────────────────────────── */
    .ptr-indicator {
      position: absolute; top: 0; left: 50%; transform: translateX(-50%) translateY(-50px);
      width: 36px; height: 36px; border-radius: 50%;
      background: var(--white); border: 1px solid var(--border);
      box-shadow: 0 2px 8px rgba(0,0,0,0.1);
      display: flex; align-items: center; justify-content: center;
      transition: transform 0.2s ease;
      z-index: 10; pointer-events: none;
    }
    .ptr-indicator.visible { transform: translateX(-50%) translateY(10px); }
    .ptr-indicator.refreshing { transform: translateX(-50%) translateY(10px); }
    .ptr-spinner {
      width: 20px; height: 20px; border: 2px solid var(--border);
      border-top-color: var(--gold); border-radius: 50%;
    }
    .ptr-spinner.spinning { animation: ptrSpin 0.6s linear infinite; }
    @keyframes ptrSpin { to { transform: rotate(360deg); } }

    /* ── PWA Install Banner ──────────────────────── */
    .pwa-banner {
      position: fixed; top: 0; left: 0; right: 0; z-index: 300;
      background: var(--dark); color: #fff; padding: 10px 16px;
      display: flex; align-items: center; justify-content: space-between;
      font-size: 13px; font-weight: 500;
      transform: translateY(-100%); transition: transform 0.3s ease;
      padding-top: calc(10px + env(safe-area-inset-top, 0px));
    }
    .pwa-banner.visible { transform: translateY(0); }
    .pwa-banner-text { flex: 1; }
    .pwa-banner-install {
      background: var(--gold); color: var(--text); border: none;
      padding: 6px 14px; border-radius: 6px; font-family: 'Inter', sans-serif;
      font-size: 13px; font-weight: 600; cursor: pointer; margin-left: 10px;
      min-height: 36px;
    }
    .pwa-banner-dismiss {
      background: none; border: none; color: rgba(255,255,255,0.6);
      cursor: pointer; font-size: 18px; margin-left: 8px; padding: 4px;
      min-width: 36px; min-height: 36px; display: flex; align-items: center; justify-content: center;
    }

    /* Sidebar overlay for mobile */
    .mobile-sidebar-overlay {
      display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.4);
      z-index: 199;
    }
    .mobile-sidebar-overlay.visible { display: block; }

    /* ── Programming View ──────────────────────── */
    .prog-week { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
    .prog-day {
      background: var(--surface-1); border: 1px solid var(--border); border-radius: 10px;
      min-height: 160px; padding: 10px; cursor: pointer; transition: box-shadow 0.15s;
      display: flex; flex-direction: column;
    }
    .prog-day:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.08); }
    .prog-day.today { border-color: var(--gold); box-shadow: 0 0 0 2px rgba(226,189,35,0.2); }
    .prog-day-header {
      font-size: 11px; font-weight: 600; color: var(--text-light);
      margin-bottom: 6px; display: flex; justify-content: space-between; align-items: center;
    }
    .prog-day-date { font-size: 13px; font-weight: 700; color: var(--text); }
    .prog-session-badge {
      font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 4px;
      text-transform: uppercase; letter-spacing: 0.5px; display: inline-block;
    }
    .prog-badge-crossfit { background: #e2bd2325; color: #b8960e; }
    .prog-badge-athletic { background: #e2bd2320; color: #b8960e; }
    .prog-badge-endurance { background: #6ba73b20; color: #6ba73b; }
    .prog-badge-hyrox { background: #ef444420; color: #ef4444; }
    .prog-badge-open_gym { background: #8b5cf620; color: #8b5cf6; }
    .prog-day-title { font-size: 12px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
    .prog-day-tags { display: flex; flex-wrap: wrap; gap: 3px; margin-top: auto; }
    .prog-tag {
      font-size: 9px; padding: 1px 5px; border-radius: 3px;
      background: #f1f5f9; color: #64748b; font-weight: 500;
    }
    .prog-day-empty {
      flex: 1; display: flex; align-items: center; justify-content: center;
      color: var(--text-light); font-size: 12px; opacity: 0.5; cursor: pointer;
    }
    .prog-day-empty:hover { opacity: 1; color: var(--gold); }
    .prog-collision-banner {
      background: #fef3c7; border: 1px solid #fcd34d; border-radius: 8px;
      padding: 10px 14px; margin-bottom: 12px; font-size: 12px; color: #92400e;
      display: flex; align-items: center; gap: 8px;
    }
    /* Editor modal */
    .prog-editor-overlay {
      position: fixed; top: 0; left: 0; right: 0; bottom: 0;
      background: rgba(0,0,0,0.4); z-index: 1000; display: flex;
      align-items: flex-start; justify-content: center; padding-top: 40px;
    }
    .prog-editor {
      background: var(--surface-1); border-radius: 12px; width: 680px; max-width: 95vw;
      max-height: 85vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.15);
    }
    .prog-editor-header {
      padding: 16px 20px; border-bottom: 1px solid var(--border);
      display: flex; justify-content: space-between; align-items: center;
    }
    .prog-editor-header h3 { margin: 0; font-size: 16px; font-weight: 700; color: var(--text); }
    .prog-editor-body { padding: 20px; }
    .prog-field { margin-bottom: 14px; }
    .prog-field label {
      display: block; font-size: 11px; font-weight: 600; color: var(--text-light);
      margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.5px;
    }
    .prog-field input, .prog-field select, .prog-field textarea {
      width: 100%; padding: 8px 10px; border: 1px solid var(--border); border-radius: 6px;
      font-size: 13px; font-family: 'Inter', sans-serif; color: var(--text); box-sizing: border-box;
    }
    .prog-field textarea { min-height: 70px; resize: vertical; }
    .prog-field textarea:focus, .prog-field input:focus, .prog-field select:focus {
      outline: none; border-color: var(--gold); box-shadow: 0 0 0 2px rgba(226,189,35,0.15);
    }
    .prog-tag-group { display: flex; flex-wrap: wrap; gap: 6px; }
    .prog-tag-btn {
      padding: 4px 10px; border-radius: 6px; border: 1px solid var(--border);
      font-size: 11px; cursor: pointer; background: var(--surface-1); color: var(--text-light);
      font-weight: 500; transition: all 0.15s;
    }
    .prog-tag-btn.selected { background: var(--gold); color: var(--text); border-color: var(--gold); font-weight: 600; }
    .prog-editor-footer {
      padding: 14px 20px; border-top: 1px solid var(--border);
      display: flex; justify-content: space-between; align-items: center;
    }
    .prog-ai-panel {
      margin-top: 14px; padding: 12px; border: 1px solid var(--border); border-radius: var(--radius-md);
      background: var(--bg);
    }
    .prog-ai-panel h4 { margin: 0 0 8px; font-size: 12px; font-weight: 700; color: var(--text); }
    .prog-ai-response {
      font-size: 12px; line-height: 1.5; color: var(--text); white-space: pre-wrap;
      max-height: 200px; overflow-y: auto; margin-top: 8px;
    }
    .prog-section-preview {
      font-size: 11px; color: var(--text-light); line-height: 1.4;
      white-space: pre-wrap; overflow: hidden; max-height: 60px;
    }
    /* ── Programming Unified Layout ──────────────── */
    .prog-unified { display: flex; height: calc(100vh - 105px); margin: -20px -24px; }
    .prog-left { flex: 1; min-width: 400px; border-right: 1px solid var(--border); background: var(--white); overflow-y: auto; display: flex; flex-direction: column; }
    .prog-left-content { flex: 1; overflow-y: auto; padding: 20px; }
    .prog-right { width: 380px; flex-shrink: 0; display: flex; flex-direction: column; background: var(--bg); overflow: hidden; }
    .prog-right-header { padding: 14px 18px; background: var(--white); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
    .prog-right-header h3 { font-size: 15px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; margin: 0; }
    .prog-quick-actions { padding: 12px 18px; border-bottom: 1px solid var(--border); background: var(--white); flex-shrink: 0; }
    .prog-quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
    .prog-quick-btn { display: flex; align-items: center; gap: 6px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--white); cursor: pointer; font-size: 11px; font-weight: 500; color: var(--text); font-family: Barlow, sans-serif; text-align: left; transition: all .15s var(--ease-out); }
    .prog-quick-btn:hover { border-color: var(--gold); background: rgba(226,189,35,0.04); }
    .prog-chat-area { flex: 1; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }
    .prog-chat-input-bar { padding: 12px 18px; border-top: 1px solid var(--border); background: var(--white); display: flex; gap: 8px; flex-shrink: 0; }
    .prog-tools-bar { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 16px; }

    @media (max-width: 768px) {
      .prog-unified { flex-direction: column; height: auto; }
      .prog-left { min-width: 0; border-right: none; border-bottom: 1px solid var(--border); max-height: 60vh; }
      .prog-right { width: 100%; height: 50vh; }
      .prog-week { grid-template-columns: 1fr; }
      .prog-editor { width: 100%; max-width: 100%; border-radius: 0; max-height: 100vh; }
      .prog-editor-overlay { padding-top: 0; }
    }

    /* ── Knowledge Unified Layout ──────────────── */
    .kb-unified { display: flex; height: calc(100vh - 105px); margin: -20px -24px; }
    .kb-left { flex: 1; min-width: 400px; border-right: 1px solid var(--border); background: var(--white); overflow-y: auto; display: flex; flex-direction: column; }
    .kb-left-content { flex: 1; overflow-y: auto; padding: 20px; }
    .kb-right { width: 380px; flex-shrink: 0; display: flex; flex-direction: column; background: var(--bg); overflow: hidden; }
    .kb-right-header { padding: 14px 18px; background: var(--white); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
    .kb-right-header h3 { font-size: 15px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; margin: 0; }
    .kb-quick-actions { padding: 12px 18px; border-bottom: 1px solid var(--border); background: var(--white); flex-shrink: 0; }
    .kb-quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
    .kb-quick-btn { display: flex; align-items: center; gap: 6px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--white); cursor: pointer; font-size: 11px; font-weight: 500; color: var(--text); font-family: Barlow, sans-serif; text-align: left; transition: all .15s var(--ease-out); }
    .kb-quick-btn:hover { border-color: #6ba73b; background: rgba(107,167,59,0.04); }
    .kb-chat-area { flex: 1; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }
    .kb-chat-input-bar { padding: 12px 18px; border-top: 1px solid var(--border); background: var(--white); display: flex; gap: 8px; flex-shrink: 0; }

    @media (max-width: 768px) {
      .kb-unified { flex-direction: column; height: auto; }
      .kb-left { min-width: 0; border-right: none; border-bottom: 1px solid var(--border); max-height: 60vh; }
      .kb-right { width: 100%; height: 50vh; }
    }

    /* ── Coming Soon Badge ──────────────────────── */
    .coming-soon-badge { background: #4a6fa5; color: #fff; font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 12px; margin-left: 8px; vertical-align: middle; letter-spacing: 0.5px; }

    /* ── Funnels Unified Layout ── */
    .funnel-unified { display: flex; height: calc(100vh - 105px); margin: -20px -24px; }
    .funnel-left { flex: 1; min-width: 400px; background: var(--white); overflow-y: auto; display: flex; flex-direction: column; }
    .funnel-left-content { flex: 1; overflow-y: auto; padding: 20px; }
    .funnel-right { display: none; }
    .funnel-right-header { padding: 14px 18px; background: var(--white); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
    .funnel-right-header h3 { font-size: 15px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; margin: 0; }
    .funnel-quick-actions { padding: 12px 18px; border-bottom: 1px solid var(--border); background: var(--white); flex-shrink: 0; }
    .funnel-quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
    .funnel-quick-btn { display: flex; align-items: center; gap: 6px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--white); cursor: pointer; font-size: 11px; font-weight: 500; color: var(--text); font-family: Barlow, sans-serif; text-align: left; transition: all .15s var(--ease-out); }
    .funnel-quick-btn:hover { border-color: #8b5cf6; background: rgba(139,92,246,0.04); }
    .funnel-chat-area { flex: 1; overflow-y: auto; padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }
    .funnel-chat-input-bar { padding: 12px 18px; border-top: 1px solid var(--border); background: var(--white); display: flex; gap: 8px; flex-shrink: 0; }

    @media (max-width: 768px) {
      .funnel-unified { flex-direction: column; height: auto; }
      .funnel-left { min-width: 0; border-right: none; border-bottom: 1px solid var(--border); max-height: 60vh; }
      .funnel-right { width: 100%; height: 50vh; }
    }

    /* ── Agent Collaboration Sidebar ─────────────────── */

    .agent-sidebar-toggle {
      position: fixed;
      right: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 32px;
      height: 80px;
      background: var(--white);
      border: 1px solid var(--border);
      border-right: none;
      border-radius: 8px 0 0 8px;
      cursor: pointer;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 6px;
      z-index: 899;
      box-shadow: -2px 0 8px rgba(0,0,0,0.06);
      transition: width 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
      overflow: hidden;
      padding: 0;
    }

    .agent-sidebar-toggle:hover {
      width: 96px;
      box-shadow: -4px 0 12px rgba(0,0,0,0.1);
    }

    .agent-sidebar-toggle .asb-toggle-initial {
      width: 24px;
      height: 24px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 11px;
      font-weight: 700;
      color: #fff;
      flex-shrink: 0;
    }

    .agent-sidebar-toggle .asb-toggle-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      flex-shrink: 0;
    }

    .agent-sidebar-toggle .asb-toggle-name {
      font-size: 10px;
      font-weight: 600;
      color: var(--text);
      white-space: nowrap;
      opacity: 0;
      max-width: 0;
      transition: opacity 0.2s var(--ease-out), max-width 0.2s var(--ease-out);
      overflow: hidden;
    }

    .agent-sidebar-toggle:hover .asb-toggle-name {
      opacity: 1;
      max-width: 60px;
    }

    .agent-sidebar-toggle.hidden { display: none; }

    .agent-sidebar {
      position: fixed;
      right: 0;
      top: 0;
      bottom: 0;
      width: 380px;
      background: var(--white);
      border-left: 1px solid var(--border);
      box-shadow: -4px 0 20px rgba(0,0,0,0.08);
      z-index: 900;
      display: flex;
      flex-direction: column;
      transform: translateX(100%);
      transition: transform 0.25s var(--ease-out);
    }

    .agent-sidebar.open {
      transform: translateX(0);
    }

    .agent-sidebar-header {
      padding: 14px 16px;
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      gap: 10px;
      flex-shrink: 0;
    }

    .agent-sidebar-header .asb-avatar {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      font-size: 12px;
      font-weight: 700;
      flex-shrink: 0;
    }

    .agent-sidebar-header .asb-info {
      flex: 1;
      min-width: 0;
    }

    .agent-sidebar-header .asb-name {
      font-weight: 700;
      font-size: 14px;
      color: var(--text);
    }

    .agent-sidebar-header .asb-role {
      font-size: 11px;
      color: var(--text-light);
    }

    .agent-sidebar-header .asb-close {
      margin-left: auto;
      background: none;
      border: none;
      font-size: 20px;
      cursor: pointer;
      color: var(--text-light);
      padding: 4px;
      line-height: 1;
      transition: color 0.15s;
    }

    .agent-sidebar-header .asb-close:hover {
      color: var(--text);
    }

    .agent-sidebar-pills {
      display: flex;
      gap: 4px;
      padding: 10px 16px;
      border-bottom: 1px solid var(--border);
      flex-shrink: 0;
    }

    .agent-sidebar-pills .asb-pill {
      padding: 5px 14px;
      border-radius: 20px;
      font-size: 12px;
      font-weight: 600;
      cursor: pointer;
      border: 1px solid var(--border);
      background: var(--white);
      color: var(--text-light);
      transition: all 0.15s var(--ease-out);
      font-family: 'Inter', sans-serif;
    }

    .agent-sidebar-pills .asb-pill:hover {
      border-color: var(--border-light);
      background: var(--bg);
    }

    .agent-sidebar-pills .asb-pill.active {
      color: #fff;
      border-color: transparent;
    }

    .asb-pill[data-agent="conversations"].active { background: var(--gold); color: var(--text); }
    .asb-pill[data-agent="marketing"].active { background: #8b5cf6; }
    .asb-pill[data-agent="systems"].active { background: var(--success); }

    .agent-sidebar-quick {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      padding: 10px 16px;
      border-bottom: 1px solid var(--border);
      flex-shrink: 0;
    }

    .agent-sidebar-quick .asb-quick-btn {
      padding: 5px 10px;
      border-radius: 6px;
      font-size: 11px;
      font-weight: 500;
      cursor: pointer;
      border: 1px solid var(--border);
      background: var(--bg);
      color: var(--text);
      transition: all 0.15s var(--ease-out);
      font-family: 'Inter', sans-serif;
    }

    .agent-sidebar-quick .asb-quick-btn:hover {
      border-color: var(--gold);
      background: rgba(226, 189, 35, 0.06);
    }

    .agent-sidebar-chat {
      flex: 1;
      overflow-y: auto;
      padding: 16px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .agent-sidebar-chat .asb-empty {
      text-align: center;
      color: var(--text-light);
      padding: 40px 16px;
    }

    .agent-sidebar-chat .asb-empty-icon {
      font-size: 36px;
      margin-bottom: 10px;
    }

    .agent-sidebar-chat .asb-empty-title {
      font-size: 14px;
      font-weight: 600;
      margin: 0 0 6px;
    }

    .agent-sidebar-chat .asb-empty-desc {
      font-size: 12px;
      opacity: 0.7;
      margin: 0 auto;
      max-width: 280px;
    }

    .agent-sidebar-chat .asb-msg {
      display: flex;
    }

    .agent-sidebar-chat .asb-msg.user { justify-content: flex-end; }
    .agent-sidebar-chat .asb-msg.assistant { justify-content: flex-start; }

    .agent-sidebar-chat .asb-bubble {
      max-width: 85%;
      padding: 10px 14px;
      font-size: 13px;
      line-height: 1.55;
    }

    .agent-sidebar-chat .asb-msg.user .asb-bubble {
      background: var(--gold);
      color: var(--text);
      border-radius: 12px 12px 4px 12px;
    }

    .agent-sidebar-chat .asb-msg.assistant .asb-bubble {
      background: var(--white);
      color: var(--text);
      border: 1px solid var(--border);
      border-radius: 12px 12px 12px 4px;
    }

    /* ── Block rendering (capabilities layer) ────────────────────────── */
    .asb-card {
      background: var(--bg-light, #f7f8fa);
      border-radius: 8px;
      padding: 10px 12px;
      margin: 8px 0;
      font-size: 12px;
    }
    .asb-card-title {
      font-weight: 700;
      font-size: 12px;
      margin-bottom: 6px;
      color: var(--text);
    }
    .asb-card-row {
      display: flex;
      justify-content: space-between;
      padding: 3px 0;
      border-bottom: 1px solid var(--border-light, rgba(0,0,0,0.05));
    }
    .asb-card-row:last-child { border-bottom: none; }
    .asb-card-key { color: var(--text-light); }
    .asb-card-val { font-weight: 600; color: var(--text); }

    .asb-media {
      margin: 8px 0;
    }
    .asb-media img, .asb-media video {
      max-width: 100%;
      border-radius: 8px;
      display: block;
    }
    .asb-media-caption {
      font-size: 11px;
      color: var(--text-light);
      margin-top: 4px;
    }

    .asb-action-btn {
      margin: 4px 4px 4px 0;
    }

    .asb-table-wrap {
      margin: 8px 0;
      overflow-x: auto;
    }
    .asb-table-caption {
      font-size: 11px;
      font-weight: 600;
      color: var(--text-light);
      margin-bottom: 4px;
    }
    .asb-table {
      width: 100%;
      font-size: 11px;
      border-collapse: collapse;
    }
    .asb-table th, .asb-table td {
      padding: 4px 8px;
      text-align: left;
      border-bottom: 1px solid var(--border-light, rgba(0,0,0,0.06));
    }
    .asb-table th {
      font-weight: 700;
      color: var(--text-light);
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: 0.3px;
    }

    .asb-preview {
      margin: 8px 0;
    }
    .asb-preview-title {
      font-size: 11px;
      font-weight: 600;
      margin-bottom: 4px;
    }

    .asb-status {
      padding: 4px 0;
    }

    .agent-sidebar-input {
      padding: 12px 16px;
      background: var(--white);
      border-top: 1px solid var(--border);
      display: flex;
      gap: 8px;
      flex-shrink: 0;
    }

    .agent-sidebar-input input {
      flex: 1;
      padding: 10px 14px;
      border: 1px solid var(--border);
      border-radius: 6px;
      font-family: 'Inter', sans-serif;
      font-size: 13px;
      outline: none;
      transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
    }

    .agent-sidebar-input input:focus {
      border-color: var(--gold);
      box-shadow: 0 0 0 3px var(--accent-glow);
    }

    .main.asb-shifted {
      transition: margin-right 0.25s var(--ease-out);
      margin-right: 380px;
    }

    @media (max-width: 768px) {
      .agent-sidebar {
        width: 100%;
        z-index: 950;
      }
      .main.asb-shifted {
        margin-right: 0 !important;
      }
      .agent-sidebar-toggle {
        bottom: 70px;
        top: auto;
        transform: none;
      }
    }

