:root {
  --red: #C41E3A; --red-light: #E8344F; --red-dark: #9A1830;
  --charcoal: #1C1C1E; --charcoal-light: #2C2C2E; --charcoal-mid: #3A3A3C;
  --gray-100: #F5F5F7; --gray-200: #E8E8ED; --gray-300: #D1D1D6;
  --gray-400: #AEAEB2; --gray-500: #8E8E93; --gray-600: #636366; --gray-700: #48484A;
  --white: #FFFFFF; --black: #000000;
  --green: #30D158; --amber: #FFD60A; --blue: #0A84FF;
  --font-body: 'DM Sans', -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --radius-sm: 6px; --radius-md: 10px; --radius-lg: 16px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.12);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.16);
}
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:var(--font-body); background:var(--gray-100); color:var(--charcoal); min-height:100vh; -webkit-font-smoothing:antialiased; }

/* LOGIN */
#login-screen { display:flex; align-items:center; justify-content:center; min-height:100vh; background:var(--charcoal); position:relative; overflow:hidden; }
#login-screen::before { content:''; position:absolute; top:-50%; right:-20%; width:600px; height:600px; background:radial-gradient(circle,rgba(196,30,58,0.15) 0%,transparent 70%); border-radius:50%; }
.login-card { background:var(--charcoal-light); border:1px solid var(--charcoal-mid); border-radius:var(--radius-lg); padding:48px 40px; width:400px; max-width:90vw; position:relative; z-index:1; }
.login-logo { font-size:28px; font-weight:700; color:var(--white); letter-spacing:3px; text-align:center; margin-bottom:6px; }
.login-logo span { color:var(--red); }
.login-subtitle { text-align:center; color:var(--gray-500); font-size:13px; margin-bottom:36px; letter-spacing:0.5px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:12px; font-weight:600; color:var(--gray-400); margin-bottom:8px; text-transform:uppercase; letter-spacing:0.8px; }
.form-group input,.form-group select,.form-group textarea { width:100%; padding:12px 16px; background:var(--charcoal); border:1px solid var(--charcoal-mid); border-radius:var(--radius-sm); color:var(--white); font-family:var(--font-body); font-size:15px; transition:border-color 0.2s; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { outline:none; border-color:var(--red); }
.form-group input::placeholder,.form-group textarea::placeholder { color:var(--gray-600); }
.btn-login { width:100%; padding:13px; background:var(--red); color:var(--white); border:none; border-radius:var(--radius-sm); font-family:var(--font-body); font-size:15px; font-weight:600; cursor:pointer; transition:background 0.2s,transform 0.1s; margin-top:8px; }
.btn-login:hover { background:var(--red-light); }
.btn-login:active { transform:scale(0.98); }
.btn-login:disabled { opacity:0.6; cursor:not-allowed; }
.login-error { color:var(--red-light); font-size:13px; text-align:center; margin-top:16px; min-height:20px; }

/* APP LAYOUT */
#app-screen { display:none; min-height:100vh; }
.sidebar { position:fixed; top:0; left:0; width:240px; height:100vh; background:var(--charcoal); display:flex; flex-direction:column; z-index:100; transition:transform 0.3s; }
.sidebar-logo { padding:24px 24px 20px; border-bottom:1px solid var(--charcoal-mid); cursor:pointer; transition:background 0.15s; }
.sidebar-logo:hover { background:var(--charcoal-light); }
.sidebar-logo h1 { font-size:22px; font-weight:700; color:var(--white); letter-spacing:2.5px; }
.sidebar-logo h1 span { color:var(--red); }
.sidebar-logo p { font-size:11px; color:var(--gray-600); margin-top:4px; letter-spacing:0.5px; }
.sidebar-nav { flex:1; padding:16px 12px; overflow-y:auto; }
.nav-section { margin-bottom:24px; }
.nav-section-title { font-size:10px; font-weight:700; color:var(--gray-600); text-transform:uppercase; letter-spacing:1.2px; padding:0 12px; margin-bottom:8px; }
.nav-item { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:var(--radius-sm); color:var(--gray-400); font-size:14px; font-weight:500; cursor:pointer; transition:all 0.15s; text-decoration:none; }
.nav-item:hover { background:var(--charcoal-light); color:var(--white); }
.nav-item.active { background:var(--red); color:var(--white); }
.nav-item svg { width:18px; height:18px; flex-shrink:0; }
.sidebar-user { padding:16px; border-top:1px solid var(--charcoal-mid); display:flex; align-items:center; gap:10px; }
.user-avatar { width:34px; height:34px; border-radius:50%; background:var(--red-dark); display:flex; align-items:center; justify-content:center; color:var(--white); font-size:13px; font-weight:700; }
.user-info { flex:1; min-width:0; }
.user-name { font-size:13px; font-weight:600; color:var(--white); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.user-role { font-size:11px; color:var(--gray-500); }
.btn-logout { background:none; border:none; color:var(--gray-600); cursor:pointer; padding:4px; border-radius:4px; transition:color 0.15s; }
.btn-logout:hover { color:var(--red-light); }
.main-content { margin-left:240px; min-height:100vh; }

/* MOBILE */
.mobile-header { display:none; position:fixed; top:0; left:0; right:0; height:56px; background:var(--charcoal); z-index:99; align-items:center; padding:0 16px; gap:12px; }
.mobile-header h1 { font-size:18px; font-weight:700; color:var(--white); letter-spacing:2px; }
.mobile-header h1 span { color:var(--red); }
.btn-menu { background:none; border:none; color:var(--white); cursor:pointer; padding:4px; }
.overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:99; }

/* GLOBAL SEARCH */
.global-search { position:sticky; top:0; z-index:50; background:var(--white); border-bottom:1px solid var(--gray-200); padding:16px 32px; }
.global-search-inner { position:relative; max-width:720px; }
.global-search-inner svg { position:absolute; left:16px; top:50%; transform:translateY(-50%); color:var(--gray-400); width:20px; height:20px; pointer-events:none; }
.global-search-inner input { width:100%; padding:14px 20px 14px 48px; background:var(--gray-100); border:2px solid var(--gray-200); border-radius:var(--radius-md); font-family:var(--font-body); font-size:16px; color:var(--charcoal); transition:all 0.2s; }
.global-search-inner input:focus { outline:none; border-color:var(--red); background:var(--white); box-shadow:0 0 0 3px rgba(196,30,58,0.1); }
.global-search-inner input::placeholder { color:var(--gray-400); }

/* LIST SUBHEADER */
.list-subheader { display:flex; align-items:center; gap:16px; padding:16px 32px 8px; flex-wrap:wrap; }
.page-title { font-size:20px; font-weight:700; }
.search-filters { display:flex; gap:8px; }
.filter-chip { padding:5px 12px; border-radius:20px; font-size:12px; font-weight:500; cursor:pointer; transition:all 0.15s; border:1px solid var(--gray-300); background:var(--white); color:var(--gray-600); }
.filter-chip:hover { border-color:var(--red); color:var(--red); }
.filter-chip.active { background:var(--red); color:var(--white); border-color:var(--red); }
.search-stats { font-size:12px; color:var(--gray-500); margin-left:auto; }

/* COMPANY LIST */
.company-list { padding:12px 32px 24px; display:grid; gap:10px; }
.company-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); padding:16px 20px; cursor:pointer; transition:all 0.15s; display:grid; grid-template-columns:1fr auto; align-items:center; gap:12px; }
.company-card:hover { border-color:var(--red); box-shadow:var(--shadow-sm); transform:translateY(-1px); }
.company-card-cancelled { background:#FAFAFA; opacity:0.75; }
.company-card-cancelled:hover { opacity:1; }
.company-card-info h3 { font-size:15px; font-weight:600; margin-bottom:4px; }
.company-card-meta { display:flex; gap:16px; flex-wrap:wrap; }
.company-card-meta span { font-size:12px; color:var(--gray-500); display:flex; align-items:center; gap:4px; }
.company-card-meta .code { font-family:var(--font-mono); font-size:11px; background:var(--gray-100); padding:2px 6px; border-radius:3px; color:var(--gray-600); }
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:11px; font-weight:600; }
.badge-active { background:#E8F9EE; color:#1B7A3D; }
.badge-cancelled { background:#FEE8EC; color:#9A1830; }
.loading-spinner { display:flex; justify-content:center; padding:48px; color:var(--gray-400); font-size:14px; }
.empty-state { text-align:center; padding:64px 24px; color:var(--gray-500); }
.empty-state h3 { font-size:16px; margin-bottom:8px; color:var(--gray-600); }
.pagination { display:flex; justify-content:center; gap:8px; padding:24px; }
.pagination button { padding:8px 16px; border:1px solid var(--gray-300); border-radius:var(--radius-sm); background:var(--white); font-family:var(--font-body); font-size:13px; cursor:pointer; transition:all 0.15s; }
.pagination button:hover { border-color:var(--red); }
.pagination button:disabled { opacity:0.4; cursor:not-allowed; }
.pagination .page-info { padding:8px 12px; font-size:13px; color:var(--gray-500); }

/* DETAIL HEADER */
#company-detail { display:none; }
.detail-header { padding:24px 32px 16px; background:var(--white); border-bottom:1px solid var(--gray-200); }
.detail-back { display:inline-flex; align-items:center; gap:6px; font-size:13px; color:var(--gray-500); cursor:pointer; margin-bottom:12px; padding:4px 0; background:none; border:none; font-family:var(--font-body); transition:color 0.15s; }
.detail-back:hover { color:var(--red); }
.detail-title-row { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.detail-title-row h2 { font-size:24px; font-weight:700; }
.detail-actions { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }

/* Contact strip below company name */
.detail-contact-strip { display:flex; gap:16px; margin-top:10px; flex-wrap:wrap; }
.contact-chip { display:inline-flex; align-items:center; gap:6px; padding:5px 14px; background:var(--gray-100); border:1px solid var(--gray-200); border-radius:20px; font-size:13px; color:var(--gray-700); }
.contact-chip svg { width:14px; height:14px; color:var(--gray-500); flex-shrink:0; }
.contact-chip a { color:var(--blue); text-decoration:none; }
.contact-chip a:hover { text-decoration:underline; }

/* Product pills at-a-glance */
.detail-products-glance { margin-top:14px; display:flex; flex-wrap:wrap; gap:6px; }
.product-pill { display:inline-block; padding:6px 14px; border-radius:6px; font-size:13px; font-weight:600; cursor:pointer; transition:all 0.15s; }
.product-pill:hover { transform:translateY(-1px); box-shadow:var(--shadow-sm); }
.product-pill.active { background:#D4EDDA; border:1.5px solid #8BC99B; color:#155724; }
.product-pill.cancelled { background:#F8D7DA; border:1.5px solid #E4A8AE; color:#721C24; opacity:0.7; }

/* TABS */
.detail-body { padding:24px 32px; }
.detail-tabs { display:flex; gap:4px; border-bottom:2px solid var(--gray-200); margin-bottom:24px; overflow-x:auto; }
.detail-tab { padding:10px 18px; font-size:13px; font-weight:600; color:var(--gray-500); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px; transition:all 0.15s; white-space:nowrap; background:none; border-top:none; border-left:none; border-right:none; font-family:var(--font-body); }
.detail-tab:hover { color:var(--charcoal); }
.detail-tab.active { color:var(--red); border-bottom-color:var(--red); }
.tab-content { display:none; }
.tab-content.active { display:block; }

/* INFO GRID - wider sections */
.info-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(360px, 1fr)); gap:20px; }
.info-section { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); padding:20px 24px; }
.info-section h4 { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--gray-500); margin-bottom:14px; padding-bottom:8px; border-bottom:1px solid var(--gray-200); }
.info-row { display:flex; justify-content:space-between; padding:7px 0; font-size:13px; gap:16px; }
.info-row .label { color:var(--gray-500); flex-shrink:0; min-width:120px; }
.info-row .value { font-weight:500; text-align:right; word-break:break-word; min-width:0; }

/* EDITABLE */
.editable-value { cursor:pointer; transition:background 0.15s; padding:2px 6px; margin:-2px -6px; border-radius:4px; }
.editable-value:hover { background:var(--gray-100); }
.editable-value::after { content:' ✎'; font-size:10px; color:var(--gray-400); opacity:0; transition:opacity 0.15s; }
.editable-value:hover::after { opacity:1; }
.edit-inline { display:flex; gap:6px; align-items:center; flex-wrap:wrap; }
.edit-inline input,.edit-inline select { padding:6px 10px; font-size:13px; font-family:var(--font-body); border:1.5px solid var(--red); border-radius:4px; background:var(--white); color:var(--charcoal); min-width:160px; }
.edit-inline input:focus,.edit-inline select:focus { outline:none; box-shadow:0 0 0 2px rgba(196,30,58,0.15); }
.edit-inline button { padding:6px 14px; font-size:12px; border-radius:4px; cursor:pointer; font-family:var(--font-body); font-weight:600; border:none; white-space:nowrap; }
.edit-save { background:var(--red); color:var(--white); }
.edit-save:hover { background:var(--red-light); }
.edit-cancel { background:var(--gray-200); color:var(--gray-600); }
.edit-cancel:hover { background:var(--gray-300); }

/* PRODUCTS (in tab) */
.product-tag { display:inline-block; padding:6px 14px; margin:4px 5px 4px 0; border-radius:6px; font-size:13px; font-weight:600; background:var(--gray-100); border:1.5px solid var(--gray-200); }
.product-tag.active { background:#D4EDDA; border-color:#8BC99B; color:#155724; }
.product-tag.cancelled { background:#F8D7DA; border-color:#E4A8AE; color:#721C24; }

/* NOTES */
.note-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); padding:16px 20px; margin-bottom:12px; }
.note-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.note-card-header h4 { font-size:13px; font-weight:600; }
.note-source { font-size:10px; font-weight:600; padding:2px 8px; border-radius:10px; text-transform:uppercase; letter-spacing:0.5px; }
.note-source.airtable { background:#FFF3E0; color:#E65100; }
.note-source.less-annoying { background:#E3F2FD; color:#1565C0; }
.note-source.crm { background:#E8F5E9; color:#2E7D32; }
.note-category { font-size:11px; color:var(--gray-500); margin-bottom:8px; }
.note-content { font-size:13px; line-height:1.6; color:var(--gray-700); white-space:pre-wrap; max-height:200px; overflow-y:auto; }
.note-content.expanded { max-height:none; }
.note-expand { font-size:12px; color:var(--red); cursor:pointer; margin-top:6px; background:none; border:none; font-family:var(--font-body); font-weight:500; }
.btn-note-action { background:none; border:none; cursor:pointer; font-size:14px; color:var(--gray-400); padding:2px 4px; border-radius:4px; transition:all 0.15s; }
.btn-note-action:hover { color:var(--charcoal); background:var(--gray-100); }
.btn-note-delete:hover { color:var(--red); background:#FEE8EC; }
.note-filters { margin-bottom:16px; }
.role-checkboxes { display:flex; gap:12px; flex-wrap:wrap; padding:8px 0; }
.role-checkbox { display:flex; align-items:center; gap:6px; font-size:14px; cursor:pointer; }
.role-checkbox input { width:auto; cursor:pointer; }
.add-note-form { background:var(--white); border:2px dashed var(--gray-300); border-radius:var(--radius-md); padding:20px; margin-bottom:20px; }
.add-note-form h4 { font-size:13px; font-weight:600; margin-bottom:12px; }
.add-note-row { display:flex; gap:10px; margin-bottom:10px; }
.add-note-row select,.add-note-row input { padding:8px 12px; border:1px solid var(--gray-300); border-radius:var(--radius-sm); font-family:var(--font-body); font-size:13px; background:var(--white); color:var(--charcoal); }
.add-note-row select:focus,.add-note-row input:focus { outline:none; border-color:var(--red); }
.add-note-textarea { width:100%; min-height:80px; padding:10px 12px; border:1px solid var(--gray-300); border-radius:var(--radius-sm); font-family:var(--font-body); font-size:13px; resize:vertical; color:var(--charcoal); margin-bottom:10px; }
.add-note-textarea:focus { outline:none; border-color:var(--red); }
.add-note-actions { display:flex; gap:8px; }

/* CONTACTS */
.contact-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); padding:14px 18px; margin-bottom:8px; }
.contact-name { font-size:14px; font-weight:600; }
.contact-detail { font-size:12px; color:var(--gray-500); }

/* VERIFICATION */
.verification-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); padding:16px 20px; margin-bottom:12px; }
.verification-status { display:inline-block; padding:3px 10px; border-radius:4px; font-size:11px; font-weight:600; }
.verification-status.complete { background:#E8F9EE; color:#1B7A3D; }
.verification-status.pending { background:#FFF8E1; color:#F57F17; }
.verification-status.cancelled { background:#FEE8EC; color:#9A1830; }

/* BUTTONS */
.btn { padding:8px 16px; border-radius:var(--radius-sm); font-family:var(--font-body); font-size:13px; font-weight:600; cursor:pointer; transition:all 0.15s; border:none; display:inline-flex; align-items:center; gap:6px; }
.btn-primary { background:var(--red); color:var(--white); }
.btn-primary:hover { background:var(--red-light); }
.btn-primary:disabled { opacity:0.5; cursor:not-allowed; }
.btn-secondary { background:var(--gray-200); color:var(--gray-700); }
.btn-secondary:hover { background:var(--gray-300); }
.btn-sm { padding:6px 12px; font-size:12px; }

/* MODAL */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:200; align-items:center; justify-content:center; }
.modal-overlay.open { display:flex; }
.modal { background:var(--white); border-radius:var(--radius-lg); width:640px; max-width:92vw; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-lg); }
.modal-header { padding:20px 24px; border-bottom:1px solid var(--gray-200); display:flex; justify-content:space-between; align-items:center; }
.modal-header h3 { font-size:18px; font-weight:700; }
.modal-close { background:none; border:none; font-size:20px; cursor:pointer; color:var(--gray-500); padding:4px; line-height:1; }
.modal-close:hover { color:var(--charcoal); }
.modal-body { padding:24px; }
.modal-body .form-group label { color:var(--gray-600); }
.modal-body .form-group input,.modal-body .form-group select,.modal-body .form-group textarea { background:var(--white); color:var(--charcoal); border-color:var(--gray-300); }
.modal-body .form-group input:focus,.modal-body .form-group select:focus,.modal-body .form-group textarea:focus { border-color:var(--red); }
.modal-body textarea { min-height:120px; resize:vertical; font-family:var(--font-body); font-size:14px; line-height:1.5; }
.modal-footer { padding:16px 24px; border-top:1px solid var(--gray-200); display:flex; justify-content:flex-end; gap:8px; }
.email-preview { background:var(--gray-100); border:1px solid var(--gray-200); border-radius:var(--radius-sm); padding:16px; margin-top:12px; font-size:13px; line-height:1.6; }
.email-preview-subject { font-weight:600; margin-bottom:8px; padding-bottom:8px; border-bottom:1px solid var(--gray-200); }

/* TOAST */
.toast-container { position:fixed; bottom:24px; right:24px; z-index:300; display:flex; flex-direction:column; gap:8px; }
.toast { padding:12px 20px; border-radius:var(--radius-sm); font-size:13px; font-weight:500; color:var(--white); box-shadow:var(--shadow-md); animation:toast-in 0.3s ease; }
.toast-success { background:#1B7A3D; }
.toast-error { background:var(--red-dark); }
@keyframes toast-in { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

/* ===== WORKSPACE ===== */
.ws-header { padding:28px 32px 20px; display:flex; justify-content:space-between; align-items:flex-start; }
.ws-greeting { font-size:28px; font-weight:700; color:var(--charcoal); }
.ws-subtitle { font-size:14px; color:var(--gray-500); margin-top:4px; }
.btn-fab { width:56px; height:56px; border-radius:50%; background:var(--red); color:var(--white); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-md); transition:all 0.2s; flex-shrink:0; }
.btn-fab:hover { background:var(--red-light); transform:scale(1.05); box-shadow:var(--shadow-lg); }
.btn-fab:active { transform:scale(0.95); }
.fab-container { position:relative; }
.fab-menu { display:none; position:absolute; top:calc(100% + 8px); right:0; background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); box-shadow:var(--shadow-lg); min-width:200px; z-index:10; overflow:hidden; }
.fab-menu.open { display:block; animation:fab-in 0.15s ease; }
@keyframes fab-in { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
.fab-menu-item { display:flex; align-items:center; gap:10px; width:100%; padding:12px 18px; border:none; background:none; font-family:var(--font-body); font-size:14px; font-weight:500; color:var(--charcoal); cursor:pointer; transition:background 0.1s; text-align:left; }
.fab-menu-item:hover { background:var(--gray-100); }
.fab-menu-item svg { color:var(--gray-500); flex-shrink:0; }
.ws-grid { display:grid; grid-template-columns:1fr 340px; grid-template-rows:auto auto; gap:20px; padding:0 32px 32px; }
.ws-tasks-section { grid-column:1; grid-row:1 / 3; }
.ws-notepad-section { grid-column:2; grid-row:1; }
.ws-recent-section { grid-column:2; grid-row:2; }
.ws-section { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); overflow:hidden; }
.ws-section-header { padding:16px 20px; border-bottom:1px solid var(--gray-200); display:flex; justify-content:space-between; align-items:center; }
.ws-section-header h3 { font-size:15px; font-weight:700; }
.ws-task-filters { display:flex; gap:4px; }
.ws-filter { padding:4px 12px; border-radius:16px; font-size:12px; font-weight:500; cursor:pointer; border:1px solid var(--gray-300); background:var(--white); color:var(--gray-600); font-family:var(--font-body); transition:all 0.15s; }
.ws-filter:hover { border-color:var(--red); color:var(--red); }
.ws-filter.active { background:var(--red); color:var(--white); border-color:var(--red); }
.ws-save-status { font-size:11px; color:var(--gray-400); }
.ws-notepad { width:100%; min-height:200px; padding:16px 20px; border:none; resize:vertical; font-family:var(--font-body); font-size:14px; line-height:1.7; color:var(--charcoal); }
.ws-notepad:focus { outline:none; }
.ws-notepad::placeholder { color:var(--gray-400); }

/* Task items */
.task-item { display:flex; align-items:flex-start; gap:12px; padding:14px 20px; border-bottom:1px solid var(--gray-100); cursor:pointer; transition:background 0.1s; }
.task-item:hover { background:var(--gray-100); }
.task-item:last-child { border-bottom:none; }
.task-check { width:20px; height:20px; border-radius:50%; border:2px solid var(--gray-300); flex-shrink:0; cursor:pointer; transition:all 0.15s; margin-top:2px; display:flex; align-items:center; justify-content:center; }
.task-check:hover { border-color:var(--green); }
.task-check.done { background:var(--green); border-color:var(--green); }
.task-check.done::after { content:'✓'; color:white; font-size:11px; font-weight:700; }
.task-info { flex:1; min-width:0; }
.task-title { font-size:14px; font-weight:500; margin-bottom:3px; }
.task-title.done { text-decoration:line-through; color:var(--gray-400); }
.task-meta { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.task-meta span { font-size:11px; color:var(--gray-500); }
.task-priority { font-size:10px; font-weight:700; padding:2px 8px; border-radius:10px; text-transform:uppercase; letter-spacing:0.5px; }
.task-priority.urgent { background:#FEE8EC; color:var(--red-dark); }
.task-priority.high { background:#FFF3E0; color:#E65100; }
.task-priority.normal { background:#E3F2FD; color:#1565C0; }
.task-priority.low { background:var(--gray-100); color:var(--gray-500); }
.task-due { font-size:11px; }
.task-due.overdue { color:var(--red); font-weight:600; }
.task-due.today { color:var(--amber); font-weight:600; }
.task-category-tag { font-size:10px; padding:2px 8px; border-radius:10px; background:var(--gray-100); color:var(--gray-600); }
.task-assignee { font-size:11px; color:var(--gray-400); }
.task-empty { padding:32px 20px; text-align:center; color:var(--gray-400); font-size:14px; }
.task-company-link { font-size:11px; color:var(--blue); cursor:pointer; }
.task-company-link:hover { text-decoration:underline; }

/* Recent list */
.recent-item { display:flex; align-items:center; gap:10px; padding:10px 20px; border-bottom:1px solid var(--gray-100); cursor:pointer; transition:background 0.1s; font-size:13px; }
.recent-item:hover { background:var(--gray-100); }
.recent-item:last-child { border-bottom:none; }
.recent-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.recent-dot.active { background:var(--green); }
.recent-dot.cancelled { background:var(--gray-300); }

/* TASKS PAGE */
.tasks-header { padding:24px 32px 16px; }
.tasks-header-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.tasks-filters { display:flex; gap:8px; }
#tasks-page-list { padding:0 32px 32px; }

/* TASK MODAL form */
.task-form-row { display:flex; gap:12px; margin-bottom:16px; }
.task-form-row > * { flex:1; }
.task-form-group { margin-bottom:16px; }
.task-form-group label { display:block; font-size:12px; font-weight:600; color:var(--gray-500); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.6px; }
.task-form-group input,.task-form-group select,.task-form-group textarea {
  width:100%; padding:10px 14px; border:1px solid var(--gray-300); border-radius:var(--radius-sm);
  font-family:var(--font-body); font-size:14px; background:var(--white); color:var(--charcoal);
}
.task-form-group input:focus,.task-form-group select:focus,.task-form-group textarea:focus { outline:none; border-color:var(--red); }
.task-form-group textarea { min-height:80px; resize:vertical; }

/* KNOWLEDGE BASE */
.kb-header { padding:24px 32px 16px; }
.kb-header .page-title { margin-bottom:16px; }
.kb-search { max-width:480px; margin-bottom:12px; }
.kb-search input { width:100%; padding:10px 16px; border:1.5px solid var(--gray-200); border-radius:var(--radius-md); font-family:var(--font-body); font-size:14px; background:var(--white); }
.kb-search input:focus { outline:none; border-color:var(--red); }
.kb-filters { display:flex; gap:6px; flex-wrap:wrap; }
.kb-grid { padding:0 32px 32px; display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)); gap:14px; }
.kb-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); padding:18px 22px; cursor:pointer; transition:all 0.15s; }
.kb-card:hover { border-color:var(--red); box-shadow:var(--shadow-sm); transform:translateY(-1px); }
.kb-card-title { font-size:15px; font-weight:600; margin-bottom:6px; }
.kb-card-meta { display:flex; gap:8px; align-items:center; margin-bottom:8px; }
.kb-card-type { font-size:10px; font-weight:600; padding:2px 8px; border-radius:10px; background:var(--gray-100); color:var(--gray-600); text-transform:uppercase; letter-spacing:0.5px; }
.kb-card-status { font-size:10px; font-weight:600; padding:2px 8px; border-radius:10px; }
.kb-card-status.archive { background:#E3F2FD; color:#1565C0; }
.kb-card-status.in-progress { background:#FFF3E0; color:#E65100; }
.kb-card-status.done { background:#E8F9EE; color:#1B7A3D; }
.kb-card-preview { font-size:12px; color:var(--gray-500); line-height:1.5; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.kb-article-content { font-size:14px; line-height:1.8; color:var(--gray-700); white-space:pre-wrap; }

/* MY NOTES / JOURNAL */
.mynotes-header { padding:24px 32px 16px; }
.mynotes-header-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.mynotes-filters { display:flex; gap:6px; flex-wrap:wrap; }
.mynotes-grid { padding:0 32px 32px; display:grid; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)); gap:14px; }
.journal-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-md); padding:18px 22px; cursor:pointer; transition:all 0.15s; position:relative; }
.journal-card:hover { border-color:var(--red); box-shadow:var(--shadow-sm); transform:translateY(-1px); }
.journal-card-pinned { position:absolute; top:12px; right:14px; color:var(--amber); font-size:14px; }
.journal-card-title { font-size:15px; font-weight:600; margin-bottom:4px; padding-right:20px; }
.journal-card-meta { display:flex; gap:8px; align-items:center; margin-bottom:8px; font-size:11px; color:var(--gray-500); }
.journal-card-preview { font-size:12px; color:var(--gray-500); line-height:1.5; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }

/* CONTACT EDITING */
.contact-card-actions { display:flex; gap:6px; }
.contact-card-actions button { padding:4px 10px; font-size:11px; border-radius:4px; cursor:pointer; font-family:var(--font-body); font-weight:500; border:1px solid var(--gray-300); background:var(--white); color:var(--gray-600); transition:all 0.15s; }
.contact-card-actions button:hover { border-color:var(--red); color:var(--red); }
.contact-card-actions .btn-delete:hover { border-color:var(--red); color:var(--red); background:#FEE8EC; }
.contact-role-tag { font-size:10px; font-weight:600; padding:2px 8px; border-radius:10px; text-transform:uppercase; letter-spacing:0.4px; }
.contact-role-tag.primary { background:#E8F9EE; color:#1B7A3D; }
.contact-role-tag.reports { background:#E3F2FD; color:#1565C0; }
.contact-role-tag.forms { background:#FFF3E0; color:#E65100; }
.contact-role-tag.billing { background:#F3E5F5; color:#7B1FA2; }
.contact-role-tag.other { background:var(--gray-100); color:var(--gray-500); }

/* TASK DETAIL */
.task-detail-grid { display:grid; grid-template-columns:1fr 200px; gap:20px; }
.task-detail-main { }
.task-detail-sidebar { }
.task-detail-field { margin-bottom:16px; }
.task-detail-field label { display:block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.6px; color:var(--gray-500); margin-bottom:6px; }
.task-detail-field .value { font-size:14px; }
.task-detail-description { font-size:14px; line-height:1.7; white-space:pre-wrap; color:var(--gray-700); background:var(--gray-100); border-radius:var(--radius-sm); padding:14px; }

/* RESPONSIVE */
@media (max-width:768px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); }
  .overlay.open { display:block; }
  .mobile-header { display:flex; }
  .main-content { margin-left:0; padding-top:56px; }
  .global-search { padding:12px 16px; }
  .list-subheader { padding:12px 16px 4px; }
  .company-list { padding:8px 16px 24px; }
  .detail-header { padding:16px; }
  .detail-body { padding:16px; }
  .info-grid { grid-template-columns:1fr; }
  .detail-tabs { gap:0; }
  .detail-tab { padding:10px 12px; font-size:12px; }
  .modal { max-width:96vw; }
  .detail-actions { width:100%; }
  .detail-actions .btn { flex:1; justify-content:center; }
  .ws-header { padding:20px 16px 16px; }
  .ws-grid { grid-template-columns:1fr; padding:0 16px 16px; }
  .ws-tasks-section { grid-column:1; grid-row:auto; }
  .ws-notepad-section { grid-column:1; grid-row:auto; }
  .ws-recent-section { grid-column:1; grid-row:auto; }
  .tasks-header { padding:16px; }
  #tasks-page-list { padding:0 16px 16px; }
}
