:root{--bg-void: #0D0D0E;--bg-base: #111113;--bg-card: #18181B;--bg-elevated: #1F1F23;--bg-hover: #26262C;--border: #2A2A30;--border-light: #333340;--orange: #E8520A;--orange-bright: #FF6B2B;--orange-muted: #C44208;--orange-glow: rgba(232, 82, 10, .15);--text-primary: #F2F2F3;--text-secondary: #9999A8;--text-muted: #55555F;--text-inverse: #0D0D0E;--success: #22C55E;--warning: #F59E0B;--danger: #EF4444;--info: #3B82F6;--blocked: #8B5CF6;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow: 0 4px 16px rgba(0,0,0,.5);--shadow-lg: 0 8px 32px rgba(0,0,0,.6);--shadow-orange: 0 0 24px rgba(232,82,10,.2);--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--transition: .18s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-void: #F5F5F7;--bg-base: #FFFFFF;--bg-card: #FFFFFF;--bg-elevated: #F0F0F3;--bg-hover: #E8E8EC;--border: #D5D5DC;--border-light: #C5C5D0;--text-primary: #1A1A1F;--text-secondary: #5C5C6A;--text-muted: #9999A8;--text-inverse: #F2F2F3;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--shadow-orange: 0 0 24px rgba(232,82,10,.12);--orange-glow: rgba(232, 82, 10, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-void);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2}h1{font-size:clamp(1.4rem,2.5vw,1.9rem)}h2{font-size:clamp(1.4rem,3vw,2rem)}h3{font-size:1.25rem}h4{font-size:1.05rem}p{color:var(--text-secondary)}a{color:var(--orange);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--orange-bright)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);border:none;font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--orange);color:#fff;box-shadow:0 0 0 0 var(--orange-glow)}.btn-primary:hover:not(:disabled){background:var(--orange-bright);box-shadow:var(--shadow-orange);transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-light)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.btn-danger{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.25)}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.card-sm{padding:16px;border-radius:var(--radius)}.form-group{display:flex;flex-direction:column;gap:8px}.label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;transition:all var(--transition);outline:none;width:100%}.input:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-glow)}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:90px}select.input{cursor:pointer}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:24px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--orange)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-todo{background:#9999a81f;color:var(--text-secondary)}.badge-in_progress{background:#3b82f626;color:var(--info)}.badge-done{background:#22c55e26;color:var(--success)}.badge-blocked{background:#8b5cf626;color:var(--blocked)}.badge-waiting{background:#f59e0b26;color:var(--warning)}.badge-overdue,.badge-high{background:#ef444426;color:var(--danger)}.badge-medium{background:#f59e0b26;color:var(--warning)}.badge-low{background:#22c55e26;color:var(--success)}.app-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.main-content{padding:32px;overflow-y:auto;max-height:100vh;background:var(--bg-base);min-width:0}.main-content>*{max-width:1200px;width:100%}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:16px;flex-wrap:wrap}.page-header-left h1{margin-bottom:4px}.page-header-left p{font-size:.9rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media(max-width:1280px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:1100px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.app-layout,.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.main-content{padding:20px;max-height:unset}}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;display:flex;flex-direction:column;gap:8px;min-width:0}.stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat-value{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-sub{font-size:.8rem;color:var(--text-secondary)}.progress-bar{height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--orange);border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-fill.success{background:var(--success)}.progress-fill.info{background:var(--info)}.table-wrap{overflow-x:auto;max-width:100%}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 16px;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:.875rem;color:var(--text-secondary)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-elevated)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;backdrop-filter:blur(4px);animation:fadeIn .15s ease}.modal{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s cubic-bezier(.34,1.56,.64,1)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700}.modal-body{display:flex;flex-direction:column;gap:18px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.sidebar{background:var(--bg-void);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{padding:28px 24px 20px;border-bottom:1px solid var(--border)}.logo-mark{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.logo-mark span{color:var(--orange)}.logo-sub{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-top:2px}.sidebar-nav{padding:16px 12px;flex:1}.nav-section-label{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;padding:12px 12px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition);text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-item.active{background:var(--orange-glow);color:var(--orange);border:1px solid rgba(232,82,10,.2)}.nav-item .nav-icon{width:18px;height:18px;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--orange);color:#fff;font-size:.68rem;font-weight:700;padding:1px 7px;border-radius:10px}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition)}.user-card:hover{background:var(--bg-elevated)}.avatar{width:34px;height:34px;border-radius:50%;background:var(--orange-glow);border:1px solid var(--orange-muted);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.8rem;font-weight:700;color:var(--orange);flex-shrink:0}.avatar-lg{width:48px;height:48px;font-size:1rem}.user-info{flex:1;min-width:0}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.72rem;color:var(--text-muted)}.task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;transition:all var(--transition);cursor:pointer}.task-card:hover{border-color:var(--border-light);background:var(--bg-elevated);transform:translateY(-1px);box-shadow:var(--shadow)}.task-card.overdue{border-left:3px solid var(--danger)}.task-card.done{opacity:.6}.task-card.task-highlight{border-color:var(--orange);box-shadow:0 0 0 2px #e8520a40,0 0 20px #e8520a26;animation:task-glow 1.5s ease-in-out 2}@keyframes task-glow{0%,to{box-shadow:0 0 0 2px #e8520a40,0 0 20px #e8520a26}50%{box-shadow:0 0 0 4px #e8520a59,0 0 30px #e8520a40}}.task-group{margin-bottom:2px}.task-group-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;user-select:none;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;transition:all var(--transition)}.task-group-header:hover{background:var(--bg-elevated);border-color:var(--border-light)}.task-group-header.expanded{border-color:var(--orange);border-bottom-left-radius:0;border-bottom-right-radius:0}.task-group-name{font-weight:700;color:var(--text-primary);letter-spacing:.02em}.task-group-count{background:var(--bg-elevated);color:var(--text-muted);font-size:.7rem;font-weight:600;padding:2px 9px;border-radius:10px;border:1px solid var(--border)}.task-title{font-weight:600;color:var(--text-primary);font-size:.9rem;margin-bottom:6px}.task-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:10px}.task-due{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.task-due.overdue{color:var(--danger)}.checklist-item{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border)}.checklist-item:last-child{border-bottom:none}.checklist-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--orange);cursor:pointer;flex-shrink:0}.checklist-item label{font-size:.875rem;color:var(--text-secondary);cursor:pointer;flex:1}.checklist-item label.checked{text-decoration:line-through;color:var(--text-muted)}.comment{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.comment:last-child{border-bottom:none}.comment-body{flex:1}.comment-header{display:flex;gap:8px;align-items:baseline;margin-bottom:4px}.comment-author{font-size:.85rem;font-weight:600;color:var(--text-primary)}.comment-time{font-size:.75rem;color:var(--text-muted)}.comment-text{font-size:.875rem;color:var(--text-secondary)}.gantt-wrap{overflow-x:auto}.gantt-row{display:flex;align-items:center;min-height:44px;border-bottom:1px solid var(--border)}.gantt-label{width:200px;flex-shrink:0;padding:8px 16px;font-size:.82rem;color:var(--text-secondary);font-weight:500}.gantt-track{flex:1;position:relative;height:44px}.gantt-bar{position:absolute;top:50%;transform:translateY(-50%);height:24px;border-radius:4px;background:var(--orange);opacity:.85;display:flex;align-items:center;padding:0 8px;font-size:.72rem;color:#fff;font-weight:600;white-space:nowrap;overflow:hidden;transition:opacity var(--transition)}.gantt-bar:hover{opacity:1}.gantt-bar.done{background:var(--success)}.gantt-bar.blocked{background:var(--blocked)}.gantt-header{display:flex;border-bottom:2px solid var(--border)}.gantt-header-label{width:200px;flex-shrink:0;padding:8px 16px}.gantt-header-dates{flex:1;display:flex}.gantt-date-col{flex:1;padding:8px 4px;font-size:.7rem;color:var(--text-muted);font-weight:600;text-align:center;border-left:1px solid var(--border)}.invite-box{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;display:flex;gap:12px;align-items:center}.invite-url{flex:1;font-size:.8rem;color:var(--orange);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.empty-state{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.empty-icon{width:56px;height:56px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.empty-state h3{color:var(--text-primary);font-size:1rem}.empty-state p{font-size:.875rem;max-width:280px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite}.spinner-lg{width:36px;height:36px;border-width:3px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:24px}.tab{padding:10px 18px;font-size:.875rem;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition);margin-bottom:-1px;background:none;border-left:none;border-right:none;border-top:none;font-family:var(--font-body)}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--orange);border-bottom-color:var(--orange)}.divider{height:1px;background:var(--border);margin:20px 0}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-4{margin-top:16px}.w-full{width:100%}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-orange{color:var(--orange)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-void);flex-direction:column;gap:16px}.dot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex-shrink:0}.dot.success{background:var(--success)}.dot.danger{background:var(--danger)}.card-accent{border-top:2px solid var(--orange)}.toast-container{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:8px;max-width:360px;width:100%;pointer-events:none}.toast{pointer-events:auto;background:var(--bg-card);border:1px solid var(--border-light);border-left:3px solid var(--orange);border-radius:var(--radius);padding:12px 16px;display:flex;gap:12px;align-items:flex-start;cursor:pointer;box-shadow:var(--shadow-lg);animation:slideInRight .25s cubic-bezier(.34,1.56,.64,1);transition:opacity var(--transition),transform var(--transition)}.toast:hover{border-color:var(--orange);transform:translate(-2px)}.toast-icon{color:var(--orange);flex-shrink:0;margin-top:2px}.toast-content{flex:1;min-width:0}.toast-title{font-size:.85rem;font-weight:600;color:var(--text-primary)}.toast-task{font-size:.75rem;color:var(--orange);margin-top:2px}.toast-preview{font-size:.8rem;color:var(--text-secondary);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;flex-shrink:0}.toast-close:hover{color:var(--text-primary)}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.notif-bell-wrapper{position:fixed;top:16px;right:24px;z-index:100;display:flex;align-items:center;justify-content:center}.notif-bell{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.notif-bell:hover{background:var(--bg-elevated);color:var(--text-primary)}.notif-bell-badge{position:absolute;top:2px;right:2px;background:var(--orange);color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:500;animation:slideDown .15s cubic-bezier(.34,1.56,.64,1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notif-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}.notif-dropdown-header h4{font-size:.9rem;margin:0}.notif-item{display:flex;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition)}.notif-item:hover{background:var(--bg-elevated)}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:var(--orange-glow)}.notif-item-content{flex:1;min-width:0}.notif-item-author{font-size:.8rem;font-weight:600;color:var(--text-primary)}.notif-item-task{font-size:.72rem;color:var(--orange)}.notif-item-preview{font-size:.78rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item-time{font-size:.68rem;color:var(--text-muted);margin-top:2px}.notif-empty{padding:24px;text-align:center;font-size:.85rem;color:var(--text-muted)}.kb-layout{display:grid;grid-template-columns:240px 1fr;gap:20px;min-height:400px}.kb-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.kb-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border)}.kb-sidebar-header h4{font-size:.9rem;margin:0}.kb-page-list{max-height:500px;overflow-y:auto}.kb-page-item{display:flex;align-items:center;gap:8px;padding:10px 16px;cursor:pointer;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--border);transition:all var(--transition)}.kb-page-item:hover{background:var(--bg-elevated)}.kb-page-item.active{background:var(--orange-glow);color:var(--orange);border-left:3px solid var(--orange)}.kb-page-delete{display:none;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;margin-left:auto}.kb-page-item:hover .kb-page-delete{display:block}.kb-page-delete:hover{color:var(--danger)}.kb-editor{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;min-height:400px}.kb-title-input{width:100%;border:none;background:none;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);outline:none;padding:0 0 12px;margin-bottom:12px;border-bottom:1px solid var(--border)}.kb-title-input::placeholder{color:var(--text-muted)}.kb-title{font-size:1.5rem;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}@media(max-width:900px){.kb-layout{grid-template-columns:1fr}.kb-sidebar{max-height:200px}}.tiptap-editor{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.tiptap-toolbar{display:flex;gap:2px;padding:8px;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-wrap:wrap}.tiptap-toolbar button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:none;cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.tiptap-toolbar button:hover{background:var(--bg-hover);color:var(--text-primary)}.tiptap-toolbar button.active{background:var(--orange-glow);color:var(--orange)}.tiptap-divider{width:1px;height:24px;background:var(--border);margin:4px;align-self:center}.tiptap-editor .tiptap{padding:16px;min-height:200px;outline:none}.tiptap-editor .tiptap p{margin-bottom:8px}.tiptap-editor .tiptap h2{margin:16px 0 8px;font-size:1.3rem}.tiptap-editor .tiptap ul,.tiptap-editor .tiptap ol{padding-left:24px;margin-bottom:8px}.tiptap-editor .tiptap li{margin-bottom:4px}.tiptap-editor .tiptap a{color:var(--orange);text-decoration:underline}.tiptap-editor .tiptap img{max-width:100%;border-radius:var(--radius);margin:8px 0}.tiptap-editor .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-muted);pointer-events:none;height:0}.tiptap-readonly .tiptap{padding:0;min-height:auto}.tiptap-readonly .tiptap p{margin-bottom:8px}.tiptap-readonly .tiptap h2{margin:16px 0 8px;font-size:1.3rem}.tiptap-readonly .tiptap ul,.tiptap-readonly .tiptap ol{padding-left:24px;margin-bottom:8px}.tiptap-readonly .tiptap a{color:var(--orange);text-decoration:underline;cursor:pointer}.tiptap-readonly .tiptap a:hover{opacity:.8}.tiptap-readonly .tiptap img{max-width:100%;border-radius:var(--radius)}.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px;min-height:400px}.kanban-column{flex:0 0 220px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;transition:border-color var(--transition)}.kanban-column-header{padding:12px 14px;border-bottom:1px solid var(--border)}.kanban-column-title{font-size:.82rem;font-weight:600;color:var(--text-primary)}.kanban-column-count{font-size:.68rem;font-weight:700;color:var(--text-muted);background:var(--bg-elevated);border-radius:10px;padding:1px 6px}.kanban-column-value{font-size:.72rem;color:var(--text-muted);margin-top:2px}.kanban-cards{flex:1;padding:8px;display:flex;flex-direction:column;gap:8px;min-height:100px}.kanban-empty{padding:20px;text-align:center;font-size:.78rem;color:var(--text-muted)}.deal-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;cursor:grab;transition:all var(--transition);touch-action:none}.deal-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.deal-card:active{cursor:grabbing}.deal-card-title{font-size:.82rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.deal-card-client{font-size:.72rem;color:var(--text-muted);margin-bottom:6px}.deal-card-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.deal-card-value{display:flex;align-items:center;gap:2px;font-size:.75rem;font-weight:700;color:var(--success)}.deal-card-date{display:flex;align-items:center;gap:3px;font-size:.7rem;color:var(--text-muted)}.deal-card-contact{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-muted);margin-top:4px}.score-slider{-webkit-appearance:none;appearance:none;height:6px;background:var(--bg-hover);border-radius:3px;outline:none;cursor:pointer}.score-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--orange);cursor:pointer;border:2px solid var(--bg-card);box-shadow:0 1px 3px #0000004d}.score-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--orange);cursor:pointer;border:2px solid var(--bg-card)}.pipeline-selector{display:flex;align-items:center;gap:8px}.pipeline-selector select{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;font-size:.82rem;color:var(--text-primary);cursor:pointer;outline:none}.pipeline-selector select:focus{border-color:var(--orange)}.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.view-toggle button{background:transparent;border:none;padding:6px 10px;cursor:pointer;color:var(--text-muted);transition:all var(--transition)}.view-toggle button.active{background:var(--orange);color:#fff}.view-toggle button:hover:not(.active){background:var(--bg-hover)}.deal-card-overdue{border-left:3px solid var(--danger)!important}.prob-badge{display:inline-flex;align-items:center;gap:2px;font-size:.68rem;font-weight:700;padding:1px 6px;border-radius:10px;background:#3b82f61f;color:var(--info)}.deal-card-owner{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--bg-hover);color:var(--text-muted);font-size:.62rem;font-weight:700;flex-shrink:0}.detail-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:16px;overflow-x:auto}.detail-tab{padding:8px 16px;font-size:.82rem;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--transition)}.detail-tab:hover{color:var(--text-primary)}.detail-tab.active{color:var(--orange);border-bottom-color:var(--orange)}.activity-timeline{display:flex;flex-direction:column;gap:0;border-left:2px solid var(--border);margin-left:10px;padding-left:0}.activity-item{display:flex;gap:10px;align-items:flex-start;padding:10px 0 10px 16px;position:relative}.activity-item:before{content:"";position:absolute;left:-6px;top:16px;width:10px;height:10px;border-radius:50%;background:var(--bg-card);border:2px solid var(--border)}.activity-item[data-type=call]:before{border-color:var(--success)}.activity-item[data-type=email]:before{border-color:var(--info)}.activity-item[data-type=meeting]:before{border-color:var(--warning)}.activity-item[data-type=note]:before{border-color:var(--text-muted)}.activity-item[data-type=stage_change]:before{border-color:var(--orange)}.activity-item[data-type=file_upload]:before{border-color:#8b5cf6}.activity-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon.call{background:#22c55e1f;color:var(--success)}.activity-icon.email{background:#3b82f61f;color:var(--info)}.activity-icon.meeting{background:#f59e0b1f;color:var(--warning)}.activity-icon.note{background:#9999a81f;color:var(--text-muted)}.activity-icon.stage_change{background:#e8520a1f;color:var(--orange)}.activity-icon.file_upload{background:#8b5cf61f;color:#8b5cf6}.activity-content{flex:1;min-width:0}.activity-title{font-size:.85rem;font-weight:600;color:var(--text-primary)}.activity-desc{font-size:.8rem;color:var(--text-secondary);margin-top:2px;white-space:pre-wrap}.activity-time{font-size:.72rem;color:var(--text-muted);margin-top:4px}.lead-score-badge{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px}.lead-score-badge.score-low{background:#ef44441f;color:var(--danger)}.lead-score-badge.score-mid{background:#f59e0b1f;color:var(--warning)}.lead-score-badge.score-high{background:#22c55e1f;color:var(--success)}.file-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);transition:background var(--transition)}.file-row:hover{background:var(--bg-hover)}.file-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:#3b82f61a;color:var(--info);flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:.72rem;color:var(--text-muted)}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;font-size:.72rem;font-weight:600;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-secondary);white-space:nowrap}.tag-remove{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;padding:0;font-size:.8rem;line-height:1}.tag-remove:hover{opacity:1}.csv-preview{max-height:200px;overflow:auto;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.78rem}.csv-preview table{width:100%;border-collapse:collapse}.csv-preview th{position:sticky;top:0;background:var(--bg-elevated);padding:6px 10px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border)}.csv-preview td{padding:4px 10px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.leaderboard-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid var(--border)}.leaderboard-row:last-child{border-bottom:none}.leaderboard-rank{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;background:var(--bg-hover);color:var(--text-muted);flex-shrink:0}.leaderboard-rank.gold{background:#f59e0b33;color:#f59e0b}.leaderboard-rank.silver{background:#a8b0c033;color:#94a3b8}.leaderboard-rank.bronze{background:#b4825033;color:#b4824f}.funnel-bar{display:flex;align-items:center;gap:10px;margin-bottom:8px}.funnel-label{width:120px;font-size:.78rem;font-weight:500;color:var(--text-primary);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.funnel-track{flex:1;height:28px;background:var(--bg-hover);border-radius:var(--radius-sm);overflow:hidden;position:relative}.funnel-fill{height:100%;border-radius:var(--radius-sm);transition:width .4s ease;display:flex;align-items:center;padding-left:8px;font-size:.72rem;font-weight:700;color:#fff;min-width:fit-content}.funnel-value{font-size:.72rem;color:var(--text-muted);width:60px;text-align:right}.deal-list-table th{cursor:pointer;user-select:none;white-space:nowrap}.deal-list-table th:hover{color:var(--orange)}.deal-list-table tr{transition:background var(--transition)}.deal-list-table tr:hover{background:var(--bg-hover)}.deal-list-table .stage-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 6px;font-size:.78rem;color:var(--text-primary);cursor:pointer;outline:none}.quota-progress{width:100%;height:8px;background:var(--bg-hover);border-radius:4px;overflow:hidden}.quota-progress-fill{height:100%;border-radius:4px;transition:width .4s ease}@media(max-width:900px){.pipeline-selector select{font-size:.78rem;padding:4px 8px}.detail-tabs{gap:0}.detail-tab{padding:6px 10px;font-size:.78rem}.activity-item{padding:8px 0 8px 12px}.file-row{padding:8px 10px}.leaderboard-row{padding:8px 10px;gap:8px}.funnel-label{width:80px;font-size:.72rem}.deal-list-table{font-size:.78rem}}@media(max-width:900px){.desktop-sidebar{display:none!important}.mobile-menu-btn{display:flex!important}.app-layout{grid-template-columns:1fr}.main-content{padding:60px 16px 20px}.toast-container{right:8px;left:8px;max-width:unset}.notif-bell-wrapper{right:16px;top:14px}.notif-dropdown{width:280px;right:0}.kanban-board{min-height:300px}.kanban-column{flex:0 0 180px}}@media(min-width:901px){.mobile-sidebar,.mobile-menu-btn{display:none!important}}.toast-general{cursor:default;border-left-width:3px;border-left-style:solid}.toast-general .toast-message{font-size:.85rem;font-weight:500;color:var(--text-primary)}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-warning{border-left-color:var(--warning)}.toast-info{border-left-color:var(--info)}.toast-general:hover{border-color:var(--border-light);transform:none}.search-modal{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:460px;display:flex;flex-direction:column;box-shadow:var(--shadow-lg),0 0 60px #0006;animation:slideUp .2s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.search-input-wrap{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}.search-input-wrap .search-icon{color:var(--text-muted);flex-shrink:0}.search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-family:var(--font-body);font-size:1rem}.search-input::placeholder{color:var(--text-muted)}.search-kbd{padding:2px 8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;font-size:.7rem;color:var(--text-muted);font-family:monospace}.search-results{overflow-y:auto;max-height:380px;padding:8px 0}.search-group{padding:0 8px}.search-group-label{display:flex;align-items:center;gap:6px;padding:8px 12px 4px;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.search-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;color:var(--text-secondary);transition:background var(--transition)}.search-item:hover,.search-item.active{background:var(--bg-elevated);color:var(--text-primary)}.search-item-sub{font-size:.75rem;color:var(--text-muted);margin-left:auto}.search-item-cat{font-size:.68rem;color:var(--text-muted);text-transform:capitalize;margin-left:auto}.skeleton-pulse{background:linear-gradient(90deg,var(--bg-elevated) 0%,var(--bg-hover) 50%,var(--bg-elevated) 100%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite}.skeleton-card{opacity:.7}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.confirm-dialog{padding:0;border-radius:var(--radius-xl);text-align:center}.page-enter{animation:pageEnter .3s ease-out}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.card{transition:border-color var(--transition),box-shadow var(--transition)}.card:hover{border-color:var(--border-light)}.stat-value{transition:color .3s ease}.btn:focus-visible,.input:focus-visible,.nav-item:focus-visible,.tab:focus-visible{outline:2px solid var(--orange);outline-offset:2px}.tabs{position:relative}.tab{transition:all var(--transition)}.tab:hover:not(.active){color:var(--text-primary);background:var(--bg-elevated);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.empty-state{text-align:center;padding:40px 20px}.empty-icon{width:56px;height:56px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--text-muted)}.empty-state h3{margin-bottom:8px;font-size:1.1rem}.empty-state p{font-size:.875rem;color:var(--text-muted);margin-bottom:16px}.input-error{border-color:var(--danger)!important;box-shadow:0 0 0 3px #ef444426!important}.field-error{font-size:.75rem;color:var(--danger);margin-top:4px}.divider{height:1px;background:var(--border);margin:16px 0}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-muted);margin-bottom:8px}.breadcrumb a{color:var(--text-muted);transition:color var(--transition)}.breadcrumb a:hover{color:var(--orange)}.breadcrumb-separator{color:var(--border-light);font-size:.7rem}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:4px 10px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:.72rem;color:var(--text-secondary);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:50}[data-tooltip]:hover:after{opacity:1}.view-toggle{display:inline-flex;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;gap:2px}.view-toggle button{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border:none;border-radius:calc(var(--radius-sm) - 2px);background:transparent;color:var(--text-muted);font-family:var(--font-body);font-size:.78rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.view-toggle button:hover{color:var(--text-primary)}.view-toggle button.active{background:var(--bg-elevated);color:var(--text-primary)}@media(max-width:900px){.page-header{flex-direction:column;gap:12px;margin-bottom:20px}.page-header .btn{width:100%;justify-content:center}.search-modal{max-width:calc(100vw - 32px);margin:0 16px}.stat-card{padding:16px}.stat-value{font-size:1.5rem}.modal{max-width:calc(100vw - 32px);padding:20px;margin:0;border-radius:var(--radius-lg)}.modal-body .form-group{margin-bottom:12px}.card[style*=sticky]{position:relative!important;top:auto!important}table{font-size:.8rem}th,td{padding:8px 10px}}@media(max-width:600px){.main-content{padding:16px 12px}h1{font-size:1.3rem}.tabs{gap:0;overflow-x:auto;flex-wrap:nowrap}.tab{white-space:nowrap;font-size:.8rem;padding:8px 12px}.kanban-board{padding-bottom:16px}.kanban-column{flex:0 0 260px}}
