:root{--primary-50: #ebf2fd;--primary-100: #d0e2fb;--primary-200: #a1c5f7;--primary-300: #72a8f3;--primary-400: #438bef;--primary-500: #166ee1;--primary-600: #1259b8;--primary-700: #0e4490;--primary-800: #0a3068;--primary-900: #061c40;--sidebar-bg: linear-gradient(180deg, #1a7ae8 0%, #1462c4 100%);--sidebar-text: #e8f0fb;--sidebar-text-active: #ffffff;--sidebar-hover: rgba(255, 255, 255, .08);--sidebar-active: rgba(255, 255, 255, .15);--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--sidebar-width: 260px;--detail-panel-width: 380px;--header-height: 52px;--border-radius: 6px;--border-color: #e5e7eb;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;font-family:var(--font-family);color:var(--gray-800)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-size:14px;line-height:1.5;background:var(--gray-50);-webkit-font-smoothing:antialiased}.app-layout{display:flex;height:100vh;overflow:hidden}.app-main{flex:1;overflow-y:auto;background:#fff}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;color:var(--sidebar-text);flex-shrink:0;overflow:hidden}.sidebar-header{padding:16px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{width:32px;height:32px;background:#ffffff26;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo svg{color:#fff}.sidebar-title h2{font-size:14px;font-weight:600;color:#fff;line-height:1.3}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.sidebar-link{display:flex;align-items:center;gap:10px;padding:8px 18px;color:var(--sidebar-text);text-decoration:none;font-size:13px;font-weight:500;transition:all .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.sidebar-link.active{background:var(--sidebar-active);color:var(--sidebar-text-active);font-weight:600}.sidebar-link-child{padding-left:48px}.sidebar-section{margin-top:4px}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 18px;color:var(--sidebar-text);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;border:none;background:none;width:100%;opacity:.7;transition:opacity .15s}.sidebar-section-header:hover{opacity:1}.sidebar-section-left{display:flex;align-items:center;gap:10px}.nav-icon-text{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:#ffffff1f;border-radius:4px;font-size:10px;font-weight:700;color:#fff}.sidebar-section-items{padding-bottom:4px}.sidebar-badge{background:#fff3;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:500}.sidebar-footer{border-top:1px solid rgba(255,255,255,.1);padding:8px 0}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 18px;margin-top:4px}.sidebar-user-avatar{width:32px;height:32px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{display:block;font-size:13px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{display:block;font-size:11px;color:var(--sidebar-text);text-transform:capitalize}.sidebar-logout{background:none;border:none;color:var(--sidebar-text);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:all .15s}.sidebar-logout:hover{background:#ffffff1a;color:#fff}.page-container{display:flex;height:100%;overflow:hidden}.page-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;transition:all .2s}.page-header{padding:16px 24px 0;display:flex;align-items:center;justify-content:space-between}.page-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px}.breadcrumb-parent{color:var(--gray-500)}.breadcrumb-separator{color:var(--gray-400)}.breadcrumb-current{color:var(--gray-800);font-weight:600}.page-toolbar{padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border-color)}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:8px}.toolbar-description{font-size:13px;color:var(--gray-500)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--border-radius);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.btn-primary:hover:not(:disabled){background:var(--primary-600)}.btn-outline{background:#fff;color:var(--gray-700);border-color:var(--gray-300)}.btn-outline:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.btn-sm{padding:4px 10px;font-size:12px}.btn-full{width:100%;justify-content:center}.btn-link{background:none;border:none;color:var(--primary-500);cursor:pointer;font-size:13px;padding:4px;font-family:inherit}.btn-link:hover{text-decoration:underline}.btn-group{display:flex;gap:2px}.btn-group .btn:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group .btn:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.btn-icon-only{padding:7px 10px}.icon-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:4px;color:var(--gray-500);display:flex;align-items:center;justify-content:center;transition:all .15s}.icon-btn:hover{background:var(--gray-100);color:var(--gray-700)}.icon-btn-primary{color:var(--primary-500)}.icon-btn-primary:hover{background:var(--primary-50);color:var(--primary-600)}.icon-btn-danger:hover{background:#fef2f2;color:var(--danger)}.icon-btn-sm{padding:4px}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.search-box{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--gray-300);border-radius:var(--border-radius);background:#fff;min-width:200px}.search-box input{border:none;outline:none;font-size:13px;width:100%;background:transparent;font-family:inherit}.search-box svg{color:var(--gray-400);flex-shrink:0}.filter-group{display:flex;gap:6px;align-items:center}.filter-dropdown-wrapper{position:relative}.filter-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--gray-300);border-radius:var(--border-radius);background:#fff;font-size:13px;cursor:pointer;color:var(--gray-600);font-family:inherit;transition:all .15s}.filter-btn:hover{border-color:var(--gray-400)}.filter-btn.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.filter-value{font-weight:500}.filter-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--border-radius);box-shadow:0 8px 24px #0000001f;z-index:50;padding:4px;max-height:300px;overflow-y:auto}.filter-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;font-size:13px;cursor:pointer;border-radius:4px;color:var(--gray-700);text-align:left;font-family:inherit}.filter-option:hover{background:var(--gray-50)}.filter-option.selected{background:var(--primary-50);color:var(--primary-700);font-weight:500}.dropdown-header{padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--gray-500);letter-spacing:.5px}.group-by-select{padding:6px 10px;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:13px;color:var(--gray-600);background:#fff;font-family:inherit;cursor:pointer}.table-container{flex:1;overflow:auto}.data-table{width:100%;border-collapse:collapse;table-layout:auto}.data-table thead{position:sticky;top:0;z-index:10}.data-table th{padding:8px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--border-color);text-align:left;white-space:nowrap}.data-table td{padding:10px 16px;border-bottom:1px solid var(--gray-100);font-size:13px;color:var(--gray-700);vertical-align:middle}.data-row{cursor:pointer;transition:background .1s}.data-row:hover{background:var(--gray-50)}.data-row.selected{background:var(--primary-50)}.group-header-row{cursor:pointer}.group-header-row td{padding:6px 16px;background:var(--gray-50);border-bottom:1px solid var(--border-color)}.group-header{display:flex;align-items:center;gap:8px}.group-count{font-size:12px;color:var(--gray-500);font-weight:500}.cell-name{font-weight:500;color:var(--gray-800)}.cell-link{color:var(--primary-500);text-decoration:none}.cell-link:hover{text-decoration:underline}.cell-tags{display:flex;gap:4px;flex-wrap:wrap}.table-empty{text-align:center;padding:48px 16px!important;color:var(--gray-400)}.table-empty svg{margin-bottom:8px}.table-empty p{font-size:14px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;font-size:12px;background:var(--gray-100);color:var(--gray-700);font-weight:500;white-space:nowrap}.tag button{background:none;border:none;cursor:pointer;color:inherit;font-size:14px;line-height:1;padding:0;margin-left:2px}.tag-sm{padding:1px 8px;font-size:11px}.tag-more{background:var(--gray-200);color:var(--gray-600)}.tag-blue{background:var(--primary-50);color:var(--primary-700)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.status-badge-sm{padding:2px 8px;font-size:11px}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.priority-badge{display:inline-flex;align-items:center;gap:4px;font-weight:500;font-size:13px}.priority-badge-sm{font-size:12px}.role-badge{display:inline-flex;align-items:center;gap:6px;color:var(--primary-600);font-weight:500}.status-indicator{font-size:12px;font-weight:500}.status-indicator.active{color:var(--success)}.status-indicator.inactive{color:var(--gray-400)}.overdue-alert{display:flex;align-items:center;gap:6px;padding:4px 12px;background:#fef2f2;color:var(--danger);border-radius:var(--border-radius);font-size:13px;font-weight:500}.detail-panel{position:relative;border-left:2px solid var(--gray-300);background:#fff;display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.detail-panel-resize-handle{position:absolute;left:-4px;top:0;bottom:0;width:8px;cursor:col-resize;display:flex;align-items:center;justify-content:center;z-index:10;color:transparent;transition:color .15s}.detail-panel-resize-handle:hover{color:var(--gray-400);background:#00000008}.detail-panel-header{padding:16px 20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:12px}.detail-panel-title{font-size:18px;font-weight:600;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-panel-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.detail-panel-body{flex:1;overflow-y:auto;padding:16px 20px}.detail-fields{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}.detail-field{display:flex;flex-direction:column;gap:4px}.detail-field label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500)}.detail-field span,.detail-field p{font-size:14px;color:var(--gray-800)}.detail-field-row{display:flex;gap:16px}.detail-field-row .detail-field{flex:1}.detail-link{color:var(--primary-500);text-decoration:none}.detail-link:hover{text-decoration:underline}.detail-tags{display:flex;flex-wrap:wrap;gap:6px}.detail-links{display:flex;flex-direction:column;gap:6px}.external-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary-500);text-decoration:none;font-size:13px}.external-link:hover{text-decoration:underline}.detail-section-divider{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);padding-top:12px;border-top:1px solid var(--gray-100);margin-top:4px}.text-muted{color:var(--gray-400)!important;font-style:italic}.text-danger{color:var(--danger)!important;font-weight:500}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;max-height:90vh;display:flex;flex-direction:column;width:100%}.modal-sm{max-width:400px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-xl{max-width:860px}.modal-header{padding:18px 24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:17px;font-weight:600}.modal-close{background:none;border:none;cursor:pointer;padding:4px;color:var(--gray-500);border-radius:4px;display:flex}.modal-close:hover{background:var(--gray-100)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-footer{padding:14px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.modal-footer-actions{display:flex;gap:8px}.entity-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:4px;flex:1}.form-group.flex-2{flex:2}.form-group label,.form-label{font-size:12px;font-weight:600;color:var(--gray-600)}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:14px;font-family:inherit;color:var(--gray-800);background:#fff;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #166ee11f}.form-group textarea{resize:vertical;min-height:60px}.form-row{display:flex;gap:12px;align-items:flex-end}.form-row-link{align-items:center}.form-section-title{font-size:13px;font-weight:600;color:var(--gray-700);padding-top:8px;border-top:1px solid var(--gray-100)}.form-help-text{font-size:12px;color:var(--gray-500);margin-top:-8px}.toggle{position:relative;display:inline-flex;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{width:36px;height:20px;background:var(--gray-300);border-radius:10px;transition:all .2s;position:relative}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:all .2s}.toggle input:checked+.toggle-slider{background:var(--primary-500)}.toggle input:checked+.toggle-slider:after{transform:translate(16px)}.toggle-label{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;color:var(--gray-700)}.toggle-label input[type=checkbox]{accent-color:var(--primary-500)}.checkbox-group{display:flex;flex-wrap:wrap;gap:8px 16px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;color:var(--gray-700)}.checkbox-label input{accent-color:var(--primary-500)}.tag-input-container{display:flex;flex-direction:column;gap:6px}.tag-list{display:flex;flex-wrap:wrap;gap:6px}.tag-input-row{display:flex;gap:6px}.tag-input-row input{flex:1;padding:6px 10px;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:13px;font-family:inherit}.tag-input-row input:focus{outline:none;border-color:var(--primary-500)}.checklist-editor{display:flex;flex-direction:column;gap:6px}.checklist-item-edit{display:flex;gap:6px;align-items:center}.checklist-item-edit input{flex:1;padding:6px 10px;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:13px;font-family:inherit}.checklist-item-edit input:focus{outline:none;border-color:var(--primary-500)}.checklist-progress{height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden;margin-bottom:8px}.checklist-progress-bar{height:100%;background:var(--primary-500);border-radius:2px;transition:width .3s}.checklist-items{display:flex;flex-direction:column;gap:2px}.checklist-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border:none;background:none;cursor:pointer;border-radius:4px;font-size:13px;color:var(--gray-700);text-align:left;width:100%;font-family:inherit;transition:background .1s}.checklist-item:hover{background:var(--gray-50)}.checklist-item.completed span{text-decoration:line-through;color:var(--gray-400)}.check-icon{flex-shrink:0;color:var(--gray-400)}.check-icon.checked{color:var(--primary-500)}.checklist-count{font-size:12px;color:var(--gray-500);font-weight:500}.checklist-count.complete{color:var(--success)}.task-description{white-space:pre-wrap;line-height:1.6}.comments-section{border-top:1px solid var(--gray-100);padding-top:16px;margin-top:8px}.comments-title{font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:12px}.comment-form{display:flex;gap:8px;margin-bottom:12px}.comment-input{flex:1;padding:8px 12px;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:13px;font-family:inherit}.comment-input:focus{outline:none;border-color:var(--primary-500)}.comments-list{display:flex;flex-direction:column;gap:10px}.comments-empty{text-align:center;color:var(--gray-400);font-size:13px;padding:16px 0}.comment-item{display:flex;gap:10px;align-items:flex-start}.comment-avatar{width:28px;height:28px;background:var(--primary-100);color:var(--primary-700);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.comment-content{flex:1;min-width:0}.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:2px}.comment-author{font-size:13px;font-weight:600;color:var(--gray-800)}.comment-time{font-size:11px;color:var(--gray-400)}.comment-text{font-size:13px;color:var(--gray-700);line-height:1.5}.attachments-section{border-top:1px solid var(--gray-100);padding-top:16px;margin-top:8px;margin-bottom:8px}.attachments-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.attachments-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--gray-700)}.attachments-list{display:flex;flex-direction:column;gap:6px}.attachments-empty{text-align:center;color:var(--gray-400);font-size:13px;padding:8px 0}.attachment-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--gray-200);border-radius:var(--border-radius)}.attachment-icon{color:var(--gray-500);flex-shrink:0}.attachment-info{flex:1;min-width:0}.attachment-name{display:block;font-size:13px;font-weight:500;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-meta{display:block;font-size:11px;color:var(--gray-400)}.attachment-actions{display:flex;gap:2px;flex-shrink:0}.multi-select{position:relative}.multi-select-control{display:flex;align-items:center;min-height:38px;padding:4px 8px;border:1px solid var(--gray-300);border-radius:var(--border-radius);cursor:pointer;gap:4px;background:#fff;transition:border-color .15s}.multi-select-control.open{border-color:var(--primary-500);box-shadow:0 0 0 3px #166ee11f}.multi-select-values{flex:1;display:flex;flex-wrap:wrap;gap:4px;min-height:24px;align-items:center}.multi-select-placeholder{color:var(--gray-400);font-size:13px}.multi-select-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--primary-50);color:var(--primary-700);border-radius:4px;font-size:12px;font-weight:500}.multi-select-tag button{background:none;border:none;cursor:pointer;padding:0;display:flex;color:inherit}.multi-select-arrow{color:var(--gray-400);flex-shrink:0}.multi-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--gray-200);border-radius:var(--border-radius);box-shadow:0 8px 24px #0000001f;z-index:50;max-height:220px;display:flex;flex-direction:column}.multi-select-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--gray-100)}.multi-select-search input{border:none;outline:none;font-size:13px;width:100%;font-family:inherit}.multi-select-search svg{color:var(--gray-400);flex-shrink:0}.multi-select-options{overflow-y:auto;padding:4px}.multi-select-option{display:block;width:100%;padding:8px 12px;border:none;background:none;font-size:13px;cursor:pointer;border-radius:4px;text-align:left;color:var(--gray-700);font-family:inherit}.multi-select-option:hover{background:var(--gray-50)}.multi-select-empty{padding:12px;text-align:center;color:var(--gray-400);font-size:13px}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d4593,#166ee1);padding:24px}.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0003}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:56px;height:56px;background:var(--primary-500);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#fff}.login-header h1{font-size:22px;font-weight:700;color:var(--gray-900);margin-bottom:4px}.login-header p{color:var(--gray-500);font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px}.login-form .form-group label{font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:4px;display:block}.login-form .form-group input{width:100%;padding:10px 14px;border:1px solid var(--gray-300);border-radius:var(--border-radius);font-size:14px;font-family:inherit}.login-form .form-group input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #166ee11f}.login-error{padding:10px 14px;background:#fef2f2;color:var(--danger);border-radius:var(--border-radius);font-size:13px}.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--gray-400);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--gray-200)}.login-footer{text-align:center;margin-top:16px}.loading-screen{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--gray-500)}.loading-spinner{width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:20px 24px}.stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:#fff;border:1px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .15s}.stat-card:hover{box-shadow:0 4px 12px #0000000f;border-color:var(--gray-300)}.stat-card-danger{border-color:#fecaca}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon-blue{background:var(--primary-50);color:var(--primary-500)}.stat-icon-green{background:#d1fae5;color:var(--success)}.stat-icon-purple{background:#ede9fe;color:#8b5cf6}.stat-icon-red{background:#fee2e2;color:var(--danger)}.stat-icon-orange{background:#fff7ed;color:#ea580c}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:28px;font-weight:700;color:var(--gray-900);line-height:1}.stat-label{font-size:13px;color:var(--gray-600);font-weight:500;margin-top:4px}.stat-sub{font-size:12px;color:var(--gray-400);margin-top:2px}.dashboard-section-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px 8px}.dashboard-section-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--gray-800)}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:0 24px 16px}.dashboard-card{border:1px solid var(--border-color);border-radius:12px;background:#fff;overflow:hidden}.dashboard-card-header{padding:14px 18px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}.dashboard-card-header h3{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--gray-800)}.dashboard-card-body{padding:14px 18px}.dashboard-empty{text-align:center;padding:24px;color:var(--gray-400)}.dashboard-empty svg{margin-bottom:8px}.dashboard-empty p{font-size:13px}.dashboard-task-list{display:flex;flex-direction:column;gap:8px}.dashboard-task-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--gray-50)}.dashboard-task-item:last-child{border-bottom:none}.dashboard-task-info{display:flex;flex-direction:column;min-width:0}.dashboard-task-title{font-size:13px;font-weight:500;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-task-due{font-size:12px;color:var(--gray-400)}.status-breakdown{display:flex;flex-direction:column;gap:10px}.status-breakdown-item{display:flex;align-items:center;gap:10px}.status-breakdown-item .status-badge{min-width:80px}.status-bar-container{flex:1;height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}.status-bar{height:100%;background:var(--primary-400);border-radius:4px;transition:width .3s}.status-count{font-size:13px;font-weight:600;color:var(--gray-700);min-width:24px;text-align:right}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;padding:20px 24px}.template-card{border:1px solid var(--border-color);border-radius:12px;padding:18px;background:#fff;transition:box-shadow .15s}.template-card:hover{box-shadow:0 4px 12px #0000000f}.template-card.inactive{opacity:.6}.template-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.template-card-header h3{font-size:15px;font-weight:600;color:var(--gray-800)}.template-card-actions{display:flex;gap:2px}.template-card-desc{font-size:13px;color:var(--gray-500);margin-bottom:12px;line-height:1.5}.template-card-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:10px}.template-meta-item{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--gray-500);background:var(--gray-50);padding:2px 8px;border-radius:4px}.template-checklist-preview{font-size:12px;color:var(--gray-500);margin-bottom:8px}.template-trigger{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--warning);background:#fffbeb;padding:6px 10px;border-radius:var(--border-radius);margin-top:8px}.template-inactive-badge{display:inline-block;font-size:11px;color:var(--gray-500);background:var(--gray-100);padding:2px 8px;border-radius:4px;margin-top:8px}.permissions-section{padding:24px;border-top:1px solid var(--border-color);margin-top:24px}.section-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--gray-800);margin-bottom:16px}.permissions-table th{text-align:center}.permissions-table td:first-child{font-weight:500}.permission-chips{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.perm-chip{font-size:10px;padding:2px 6px;border-radius:3px;background:var(--gray-100);color:var(--gray-600);font-weight:500;text-transform:uppercase}.perm-chip.perm-full{background:var(--primary-50);color:var(--primary-600)}.user-cell{display:flex;align-items:center;gap:10px}.user-avatar-sm{width:28px;height:28px;background:var(--primary-100);color:var(--primary-700);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.action-buttons{display:flex;gap:4px}.empty-state{grid-column:1 / -1;text-align:center;padding:60px 24px;color:var(--gray-400)}.empty-state svg{margin-bottom:12px}.empty-state h3{font-size:18px;color:var(--gray-600);margin-bottom:6px}.empty-state p{font-size:14px;margin-bottom:16px}.detail-edit-form{display:flex;flex-direction:column;gap:0;margin-bottom:20px}.edit-field-group{display:flex;align-items:center;gap:0;padding:8px 0;border-bottom:1px solid var(--gray-100)}.edit-field-group:last-child{border-bottom:none}.edit-field-group label{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.3px;min-width:110px;flex-shrink:0}.edit-field-group input,.edit-field-group select,.edit-field-group textarea{flex:1;padding:6px 10px;border:1px solid transparent;border-radius:4px;font-size:14px;font-family:inherit;color:var(--gray-800);background:var(--gray-50);transition:all .15s;min-width:0}.edit-field-group input:hover,.edit-field-group select:hover,.edit-field-group textarea:hover{border-color:var(--gray-300);background:#fff}.edit-field-group input:focus,.edit-field-group select:focus,.edit-field-group textarea:focus{outline:none;border-color:var(--primary-500);background:#fff;box-shadow:0 0 0 2px #166ee11a}.edit-field-group textarea{resize:vertical;min-height:60px}.edit-section-divider{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);padding:12px 0 6px;margin-top:4px;border-top:1px solid var(--gray-200)}.edit-link-row{display:flex;gap:6px;align-items:center;padding:4px 0}.edit-link-row input{flex:1;padding:6px 10px;border:1px solid transparent;border-radius:4px;font-size:13px;font-family:inherit;background:var(--gray-50);transition:all .15s}.edit-link-row input:hover{border-color:var(--gray-300);background:#fff}.edit-link-row input:focus{outline:none;border-color:var(--primary-500);background:#fff}.comment-image{margin-top:6px;max-width:200px;max-height:150px;object-fit:cover;border-radius:6px;border:1px solid var(--gray-200);cursor:pointer;transition:opacity .15s}.comment-image:hover{opacity:.9}.comment-form-wrapper{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.comment-input-row{display:flex;gap:8px;align-items:flex-end;position:relative}.comment-attach-actions{display:flex;gap:2px;flex-shrink:0}.comment-image-preview{position:relative;display:inline-block}.comment-image-preview img{max-height:80px;border-radius:6px;border:1px solid var(--gray-200)}.comment-image-preview button{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--danger);color:#fff;border:2px solid white;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;padding:0}.mention-dropdown{position:absolute;bottom:100%;left:0;right:0;max-height:180px;overflow-y:auto;background:#fff;border:1px solid var(--gray-200);border-radius:var(--border-radius);box-shadow:0 8px 24px #0000001f;z-index:50;margin-bottom:4px}.mention-section-header{padding:6px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-400);background:var(--gray-50)}.mention-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;font-size:13px;cursor:pointer;text-align:left;color:var(--gray-700);font-family:inherit}.mention-option:hover,.mention-option.active{background:var(--primary-50);color:var(--primary-700)}.mention-tag{color:var(--primary-600);font-weight:600}.comment-text .mention-tag{background:var(--primary-50);padding:1px 4px;border-radius:3px}.attachment-name-editable{display:flex;align-items:center;gap:4px}.attachment-name-editable .icon-btn{opacity:0;transition:opacity .15s}.attachment-item:hover .attachment-name-editable .icon-btn{opacity:1}.attachment-rename-input{padding:2px 6px;border:1px solid var(--primary-500);border-radius:3px;font-size:13px;font-family:inherit;width:100%}.attachment-rename-input:focus{outline:none;box-shadow:0 0 0 2px #166ee11a}.screenshot-crop-overlay{position:fixed;inset:0;background:#000000d9;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.screenshot-crop-container{display:flex;flex-direction:column;align-items:center;max-width:90vw;max-height:90vh;overflow:hidden}.screenshot-crop-container canvas{max-height:calc(90vh - 100px);object-fit:contain}.screenshot-crop-buttons{display:flex;gap:8px;margin-top:12px;justify-content:center;flex-shrink:0}.comment-edit-row{display:flex;gap:4px;align-items:center;margin-top:2px}.comment-edit-row .comment-input{flex:1;padding:4px 8px;font-size:13px}.comment-actions-col{display:flex;flex-direction:column;gap:2px;opacity:0;transition:opacity .15s;flex-shrink:0}.comment-item:hover .comment-actions-col{opacity:1}@media(max-width:1200px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.sidebar{width:60px}.sidebar-title,.sidebar-section-header span,.sidebar-link span,.sidebar-badge,.sidebar-user-info,.sidebar-section-header svg:last-child{display:none}.sidebar-link{justify-content:center;padding:10px}.sidebar-link-child{padding-left:10px}.sidebar-section-header,.sidebar-user{justify-content:center;padding:8px}.sidebar-logout{display:none}.detail-panel{position:fixed;right:0;top:0;bottom:0;z-index:50;box-shadow:-4px 0 12px #0000001a}}.dashboard-card-header .count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:11px;font-weight:600;background:var(--gray-200);color:var(--gray-600)}.dashboard-card-header .count-badge.danger{background:#fee2e2;color:var(--danger)}.dashboard-pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 0 0;border-top:1px solid var(--gray-100);margin-top:4px}.dashboard-pagination button{background:none;border:1px solid var(--gray-300);border-radius:4px;padding:2px 10px;font-size:12px;cursor:pointer;color:var(--gray-600);font-family:inherit;transition:all .15s}.dashboard-pagination button:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.dashboard-pagination button:disabled{opacity:.4;cursor:not-allowed}.dashboard-pagination span{font-size:12px;color:var(--gray-500)}.task-stat-tiles{display:flex;gap:12px;padding:0 24px 12px}.task-stat-tile{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;background:#fff;cursor:pointer;transition:all .15s;flex:1}.task-stat-tile:hover{box-shadow:0 2px 8px #0000000f}.task-stat-tile.danger{border-color:#fecaca}.task-stat-tile .tile-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.task-stat-tile .tile-value{font-size:20px;font-weight:700;line-height:1}.task-stat-tile .tile-label{font-size:12px;color:var(--gray-500);font-weight:500}.impersonation-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;background:#fffbeb;border-bottom:1px solid #fde68a;color:#92400e;font-size:13px;font-weight:500}.impersonation-banner button{padding:3px 12px;border-radius:4px;border:1px solid #f59e0b;background:#fff;color:#92400e;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.impersonation-banner button:hover{background:#fef3c7}.comment-edit-image{display:flex;align-items:center;gap:8px;margin-top:4px}.comment-edit-image img{max-height:60px;border-radius:4px;border:1px solid var(--gray-200)}.comment-edit-image-actions{display:flex;gap:4px}
