:root,[data-theme=dark]{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-card: #22262f;--bg-input: #2a2f3a;--bg-hover: #2e3340;--text-primary: #e8eaf0;--text-secondary: #9aa0b4;--text-muted: #5d6478;--accent: #4f8ef7;--accent-hover: #3a7ae8;--success: #22c55e;--warning: #f5a623;--danger: #ef4444;--critical: #dc2626;--border: #2e3340;--sidebar-width: 260px;--sidebar-collapsed: 64px;--topbar-height: 56px;--radius: 10px;--radius-sm: 6px;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5)}[data-theme=light]{--bg-primary: #f5f7fa;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-input: #f0f2f5;--bg-hover: #e8edf2;--text-primary: #1a1d27;--text-secondary: #5a6070;--text-muted: #8b92a5;--accent: #2563eb;--accent-hover: #1d4ed8;--success: #16a34a;--warning: #d97706;--danger: #dc2626;--critical: #b91c1c;--border: #e2e5eb;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5;overflow-x:hidden}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:inherit}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width .2s ease;overflow-x:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border);min-height:56px;background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(79,142,247,.08) 100%)}.logo{font-size:20px;font-weight:700;color:var(--accent);white-space:nowrap}.collapse-btn{background:none;border:none;color:var(--text-muted);padding:4px;border-radius:4px}.collapse-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.nav-section{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:16px 12px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;border:none;background:none;width:100%;text-align:left;white-space:nowrap;transition:all .15s ease}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent);color:#fff}.board-icon{font-size:16px;flex-shrink:0}.board-name{flex:1;overflow:hidden;text-overflow:ellipsis}.badge{font-size:11px;background:var(--bg-input);padding:1px 6px;border-radius:10px;color:var(--text-muted)}.nav-item.active .badge{background:#fff3;color:#fff}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.user-info{display:flex;align-items:center;gap:10px;padding:8px;margin-bottom:4px}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#fff;flex-shrink:0}.user-name{font-size:13px;font-weight:500}.user-role{font-size:11px;color:var(--text-muted)}.logout-btn{color:var(--danger)!important}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:101;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);padding:8px;border-radius:var(--radius-sm)}.main-content{margin-left:var(--sidebar-width);flex:1;transition:margin-left .2s ease;width:0;min-width:0}.main-content.expanded{margin-left:var(--sidebar-collapsed)}.topbar{height:var(--topbar-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50;gap:16px}.search-form{display:flex;align-items:center;background:var(--bg-input);border-radius:20px;padding:0 16px;flex:1;max-width:520px;border:1px solid transparent;transition:all .2s}.search-form:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #4f8ef726}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{background:none;border:none;color:var(--text-primary);padding:8px 10px;font-size:13px;width:100%;outline:none}.search-input::placeholder{color:var(--text-muted)}.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.topbar-profile{position:relative}.topbar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;letter-spacing:.5px;border:2px solid transparent;cursor:pointer;transition:all .2s}.topbar-avatar:hover{border-color:var(--accent);box-shadow:0 0 0 3px #4f8ef733;transform:scale(1.05)}.profile-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:300px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px #00000080;z-index:200;overflow:hidden;animation:dropdown-enter .15s ease-out}@keyframes dropdown-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.profile-dropdown-header{display:flex;align-items:center;gap:14px;padding:20px;background:linear-gradient(135deg,#4f8ef714,#8b5cf60d)}.profile-dropdown-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0;box-shadow:0 2px 8px #4f8ef74d}.profile-dropdown-divider{height:1px;background:var(--border);margin:0}.profile-dropdown-item{padding:11px 20px;font-size:13px;cursor:pointer;transition:all .1s;color:var(--text-secondary);display:flex;align-items:center;gap:10px}.profile-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary);padding-left:24px}.profile-dropdown-item.danger{color:var(--danger)}.profile-dropdown-item.danger:hover{background:#ef44441a;padding-left:24px}.page-content{padding:24px;height:calc(100vh - var(--topbar-height));overflow-y:auto;overflow-x:hidden}.page-content:has(.kanban-page){overflow:hidden}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-title{font-size:22px;font-weight:700}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:2px}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:15px;font-weight:600}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:none;transition:all .15s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-input);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--success);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:6px;background:none;border:none;color:var(--text-muted);border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-textarea{resize:vertical;min-height:80px}.form-select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.form-row{display:flex;gap:12px}.form-row>*{flex:1}.form-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.form-checkbox input[type=checkbox]{accent-color:var(--accent)}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px}th{font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px}tr:hover td{background:var(--bg-hover)}.alert{padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}.alert-error{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.alert-success{background:#22c55e26;color:var(--success);border:1px solid rgba(34,197,94,.3)}.alert-warning{background:#f5a62326;color:var(--warning);border:1px solid rgba(245,166,35,.3)}.priority-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.priority-critical{background:var(--critical);animation:pulse-critical 1.2s ease-in-out infinite}@keyframes pulse-critical{0%,to{box-shadow:0 0 #dc262680}50%{box-shadow:0 0 0 5px #dc262600}}.priority-high{background:var(--warning)}.priority-normal{background:var(--success)}.priority-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;padding:2px 8px;border-radius:10px;background:var(--bg-input)}.kanban-page{height:calc(100vh - var(--topbar-height) - 48px);display:flex;flex-direction:column;overflow:hidden}.kanban-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-bottom:12px;flex-shrink:0}.kanban-board{flex:1;display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;padding-bottom:16px;scroll-behavior:smooth}.kanban-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:36px;height:36px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d;transition:all .15s}.kanban-scroll-btn:hover{background:var(--accent);color:#fff}.kanban-scroll-btn.left{left:4px}.kanban-scroll-btn.right{right:4px}.kanban-board-wrapper{position:relative;flex:1;min-height:0}.kanban-edge-scroll{position:absolute;top:0;bottom:0;width:60px;z-index:20}.kanban-edge-scroll.left{left:0;background:linear-gradient(to right,rgba(79,142,247,.15),transparent);cursor:w-resize}.kanban-edge-scroll.right{right:0;background:linear-gradient(to left,rgba(79,142,247,.15),transparent);cursor:e-resize}.kanban-column{width:290px;min-width:290px;flex-shrink:0;background:var(--bg-secondary);border-radius:var(--radius);border:1px solid var(--border);display:flex;flex-direction:column;max-height:calc(100vh - var(--topbar-height) - 160px);transition:border-color .2s,box-shadow .2s}.column-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:2px solid;flex-shrink:0;background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%)}.column-title{font-size:13px;font-weight:600}.column-count{font-size:11px;background:var(--bg-input);padding:1px 8px;border-radius:10px;color:var(--text-muted)}.column-cards{flex:1;overflow-y:auto;padding:8px}.ticket-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px;cursor:pointer;transition:all .15s ease}.ticket-card:hover{border-color:var(--accent);transform:translateY(-1px)}.ticket-card.dragging{opacity:.8;box-shadow:0 8px 24px #0000004d}.card-id{font-size:11px;color:var(--text-muted);margin-bottom:4px}.card-title-text{font-size:13px;font-weight:500;margin-bottom:8px}.card-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-muted)}.card-assignee{display:flex;align-items:center;gap:5px}.card-avatar{width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.card-days{font-size:11px;color:var(--text-muted)}.card-move-select{width:28px;height:22px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:11px;cursor:pointer;padding:0 2px;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center;opacity:0;transition:opacity .15s}.ticket-card:hover .card-move-select{opacity:1}.card-move-select:hover{border-color:var(--accent);color:var(--accent)}.card-move-select:focus{opacity:1}.load-more-btn{width:100%;padding:8px;margin-top:4px;background:var(--bg-input);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;cursor:pointer}.load-more-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.ticket-detail{max-width:1600px}.ticket-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.ticket-header-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:13px}.ticket-id-badge{background:var(--bg-input);padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600;color:var(--text-muted)}.ticket-board-link{color:var(--accent);font-size:13px}.ticket-stage-badge{padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}.ticket-priority-pill{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:600;text-transform:capitalize}.ticket-detail .detail-grid{display:grid;grid-template-columns:1.8fr 1fr;gap:20px}.detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;transition:border-color .15s}.detail-card:hover{border-color:#4f8ef733}.detail-card-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:14px}.custom-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.custom-field-label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.custom-field-input{font-size:13px!important}.custom-field-readonly{font-size:13px;color:var(--text-primary);padding:8px 12px;background:var(--bg-input);border-radius:var(--radius-sm);border:1px dashed var(--border);opacity:.8}.property-group{margin-bottom:14px}.property-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:5px}.property-divider{height:1px;background:var(--border);margin:16px 0}.property-info{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text-muted)}.property-info div{display:flex;align-items:center;gap:6px}.property-info strong{color:var(--text-primary)}.detail-tabs{display:flex;border-bottom:1px solid var(--border)}.detail-tab{display:flex;align-items:center;gap:6px;padding:12px 18px;font-size:13px;color:var(--text-secondary);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.detail-tab:hover{color:var(--text-primary)}.detail-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.comment-form{display:flex;gap:8px;margin-bottom:16px}.comment-item{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}.comment-item:last-child{border-bottom:none}.comment-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.comment-content{flex:1;min-width:0}.activity-timeline{display:flex;flex-direction:column}.activity-item{display:flex;gap:12px;font-size:13px;color:var(--text-secondary);border-left:2px solid var(--border);padding:10px 0 10px 16px;margin-left:6px;position:relative}.activity-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);position:absolute;left:-6px;top:14px}.activity-detail{color:var(--text-muted)}.activity-time{font-size:11px;color:var(--text-muted);margin-top:2px}.activity-content strong{color:var(--text-primary)}.attachment-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.attachment-item a{color:var(--accent)}.attachment-meta{font-size:11px;color:var(--text-muted);margin-left:auto}.empty-tab{text-align:center;padding:24px;color:var(--text-muted);font-size:13px}.comment-list{display:flex;flex-direction:column;gap:12px}.comment{background:var(--bg-input);border-radius:var(--radius-sm);padding:12px}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.comment-author{font-size:13px;font-weight:500}.comment-date{font-size:11px;color:var(--text-muted)}.comment-body{font-size:13px;color:var(--text-secondary);white-space:pre-wrap}.inline-edit-title{background:transparent;border:1px solid transparent;color:var(--text-primary);font-size:inherit;font-weight:inherit;font-family:inherit;padding:2px 6px;border-radius:4px;flex:1;min-width:0;outline:none;transition:border-color .15s,background .15s}.inline-edit-title:hover{border-color:var(--border)}.inline-edit-title:focus{border-color:var(--accent);background:var(--bg-input)}.inline-edit-textarea{width:100%;background:transparent;border:1px solid transparent;color:var(--text-secondary);font-size:13px;font-family:inherit;padding:8px;border-radius:6px;resize:vertical;min-height:80px;outline:none;line-height:1.6;white-space:pre-wrap;transition:border-color .15s,background .15s}.inline-edit-textarea:hover{border-color:var(--border)}.inline-edit-textarea:focus{border-color:var(--accent);background:var(--bg-input)}.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.board-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:all .15s ease}.board-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 24px #00000040}.board-card-icon{font-size:28px;margin-bottom:8px}.board-card-name{font-size:16px;font-weight:600;margin-bottom:4px}.board-card-desc{font-size:12px;color:var(--text-secondary);margin-bottom:12px}.board-card-footer{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .15s ease}.stat-card:hover{border-color:var(--accent)}.stat-value{font-size:28px;font-weight:700;margin-bottom:4px}.stat-label{font-size:12px;color:var(--text-secondary)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:10px 20px;font-size:13px;color:var(--text-secondary);border:none;background:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:24px}.modal-title{font-size:18px;font-weight:600;margin-bottom:20px}.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.filter-bar .form-select,.filter-bar .form-input{width:auto;min-width:140px}.pagination{display:flex;align-items:center;gap:8px;margin-top:20px;justify-content:center}.pagination .btn{min-width:36px;justify-content:center}.pagination .page-info{font-size:13px;color:var(--text-secondary)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:14px}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{display:block}.mobile-menu-btn{display:flex}.main-content{margin-left:0!important}.page-content{padding:16px}.kanban-column{min-width:260px}.detail-grid{grid-template-columns:1fr!important}.form-row{flex-direction:column}.charts-grid{grid-template-columns:1fr}.topbar{padding:0 16px 0 56px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:100%;max-width:400px;animation:auth-glow 3s ease-in-out infinite alternate}@keyframes auth-glow{0%{box-shadow:0 0 12px #4f8ef70d}to{box-shadow:0 0 20px #4f8ef71f}}.auth-logo{font-size:28px;font-weight:700;color:var(--accent);text-align:center;margin-bottom:8px}.auth-subtitle{font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:32px}.auth-card .btn-primary{width:100%;justify-content:center;padding:10px}.ms-login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 16px;background:#fff;color:#3c4043;border:1px solid #dadce0;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,box-shadow .15s;font-family:inherit}.ms-login-btn:hover:not(:disabled){background:#f7f8f8;box-shadow:0 1px 3px #00000026}.ms-login-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;margin:20px 0;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-divider span{font-size:12px;color:var(--text-muted);white-space:nowrap}.login-notice{display:flex;align-items:center;justify-content:space-between;padding:8px 24px;background:#4f8ef71a;border-bottom:1px solid rgba(79,142,247,.2);font-size:12px;color:var(--accent)}.login-notice-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:2px 6px}.login-notice-close:hover{color:var(--text-primary)}.idle-warning{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;background:#f5a62326;border-bottom:1px solid rgba(245,166,35,.3);font-size:13px;color:var(--warning);font-weight:500;animation:pulse-warning 1s ease-in-out infinite alternate}@keyframes pulse-warning{0%{opacity:.8}to{opacity:1}}.auth-link{display:block;text-align:center;font-size:13px;color:var(--accent);margin-top:16px}.login-split{display:flex;min-height:100vh;background:var(--bg-primary)}.login-hero{flex:1.2;background:linear-gradient(135deg,#0f1729,#1a1040 40%,#0f2027);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:60px}[data-theme=light] .login-hero{background:linear-gradient(135deg,#0c1445,#1a237e,#283593,#3949ab,#5c6bc0)}[data-theme=light] .login-hero .shape-1{opacity:.12;background:#7c4dff}[data-theme=light] .login-hero .shape-2{opacity:.1;background:#448aff}[data-theme=light] .login-hero .shape-3{opacity:.15;background:#69f0ae}[data-theme=light] .login-hero .shape-4{opacity:.1;background:#ffd740}[data-theme=light] .login-hero .shape-5{opacity:.08;background:#ff6e40}[data-theme=light] .mini-kanban{background:#ffffff1a;border-color:#ffffff26}[data-theme=light] .mini-card{background:#ffffff26}[data-theme=light] .login-quote{background:#ffffff14;border-left-color:#7c4dff}[data-theme=light] .login-form-side{background:linear-gradient(180deg,#f8fafc,#eef2ff,#e8eaf6);border-left:1px solid #e2e8f0}[data-theme=light] .login-form-card{background:#fff;padding:36px;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 4px 24px #0000000f,0 1px 3px #0000000a}[data-theme=light] .login-form-title{color:#0f172a}[data-theme=light] .login-submit{background:linear-gradient(135deg,#2563eb,#7c3aed);border:none}[data-theme=light] .login-submit:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#6d28d9);box-shadow:0 4px 16px #2563eb4d}[data-theme=light] .ms-login-btn{border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000f}[data-theme=light] .form-input{border-color:#e2e8f0;background:#f8fafc}[data-theme=light] .form-input:focus{border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61f}[data-theme=light] .standard-badge{background:#fff;border-color:#e2e8f0;box-shadow:0 1px 2px #0000000a}[data-theme=light] .standard-badge:hover{background:#eef2ff;border-color:#3b82f6}[data-theme=light] .standard-badge:after{background:#fff;border-color:#e2e8f0;box-shadow:0 8px 24px #0000001a;color:#334155}[data-theme=light] .theme-toggle-btn{background:#fff;border-color:#e2e8f0;color:#64748b;box-shadow:0 1px 3px #0000000f}[data-theme=light] .login-form-footer{color:#94a3b8}[data-theme=light] .login-powered-by strong{color:#334155}.login-hero-content{position:relative;z-index:2;max-width:520px}.login-logo-large{font-size:32px;font-weight:800;color:#fff;display:flex;align-items:center;gap:12px;margin-bottom:24px}.login-logo-icon{font-size:36px;color:var(--accent);filter:drop-shadow(0 0 12px rgba(79,142,247,.5))}.login-headline{font-size:44px;font-weight:800;color:#fff;line-height:1.15;margin-bottom:20px;letter-spacing:-.5px}.login-tagline{font-size:16px;color:#ffffffb3;line-height:1.7;margin-bottom:40px}.typing-cursor{animation:blink .8s ease-in-out infinite;color:var(--accent);font-weight:300}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.mini-kanban{display:flex;gap:10px;margin-bottom:32px;padding:16px;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mini-col{flex:1;min-width:0}.mini-col-header{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#ffffff80;margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid rgba(255,255,255,.1)}.mini-col-cards{display:flex;flex-direction:column;gap:6px;min-height:80px}.mini-card{padding:6px 10px;background:#ffffff14;border-radius:6px;font-size:11px;color:#fffc;border-left:3px solid;transition:all .5s ease;animation:card-slide-in .5s ease-out}@keyframes card-slide-in{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.login-quote{padding:16px 20px;background:#ffffff0a;border-left:3px solid var(--accent);border-radius:0 8px 8px 0;opacity:0;transform:translateY(5px);transition:opacity .5s ease,transform .5s ease}.login-quote.visible{opacity:1;transform:translateY(0)}.login-quote p{font-size:14px;color:#fffc;font-style:italic;line-height:1.6;margin:0 0 6px}.login-quote span{font-size:11px;color:#fff6;font-weight:600}.login-standards{display:flex;gap:8px;justify-content:center;margin-bottom:4px}.standard-badge{font-size:10px;font-weight:600;padding:4px 10px;border-radius:6px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);cursor:default;position:relative;display:flex;align-items:center;gap:4px;transition:all .2s}.standard-badge:hover{border-color:var(--accent);color:var(--accent);background:#4f8ef714}.standard-icon{font-size:11px}.standard-badge:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;font-size:12px;font-weight:400;color:var(--text-secondary);white-space:normal;width:240px;text-align:center;line-height:1.5;box-shadow:0 8px 24px #0006;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;pointer-events:none;z-index:10}.standard-badge:before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:10}.standard-badge:hover:after,.standard-badge:hover:before{opacity:1;visibility:visible}.login-shapes{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.shape{position:absolute;border-radius:50%;opacity:.08;animation:float 20s ease-in-out infinite}.shape-1{width:400px;height:400px;background:var(--accent);top:-100px;right:-100px;animation-delay:0s}.shape-2{width:250px;height:250px;background:#8b5cf6;bottom:-80px;left:-60px;animation-delay:-5s;animation-duration:25s}.shape-3{width:150px;height:150px;background:#22c55e;top:40%;left:60%;animation-delay:-10s;animation-duration:18s}.shape-4{width:100px;height:100px;background:#f5a623;top:20%;left:20%;animation-delay:-15s;animation-duration:22s}.shape-5{width:200px;height:200px;background:var(--accent);bottom:20%;right:10%;animation-delay:-8s;animation-duration:30s}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-40px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(40px,30px) scale(1.02)}}.login-form-side{flex:.8;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:60px 40px 40px;background:linear-gradient(180deg,#0f1117,#131620 40%,#161a28);position:relative;border-left:1px solid rgba(79,142,247,.1)}.login-form-header{position:absolute;top:20px;right:20px}.theme-toggle-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);padding:8px;border-radius:50%;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.theme-toggle-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.login-form-card{width:100%;max-width:380px}.login-form-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.login-form-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:32px}.login-submit{width:100%;padding:11px;font-size:14px;font-weight:600;justify-content:center;border-radius:8px}.login-form-footer{position:absolute;bottom:20px;font-size:11px;color:var(--text-muted);text-align:center}.login-powered-by{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:6px}.login-ibiot-formside{height:34px;width:auto;object-fit:contain;transition:all .3s ease}.login-logo-formside{font-size:28px;font-weight:800;color:var(--text-primary);display:flex;align-items:center;gap:10px;margin-bottom:16px}.login-ibiot-corner{position:absolute;top:24px;left:28px;height:56px;width:auto;object-fit:contain;z-index:3;filter:drop-shadow(0 1px 6px rgba(0,0,0,.3));transition:all .3s ease}.login-ibiot-corner:hover{transform:scale(1.03)}@media(max-width:900px){.login-split{flex-direction:column}.login-hero{min-height:300px;padding:40px;flex:none}.login-headline{font-size:28px}.login-features{display:none}.login-form-side{padding:24px;flex:1}}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:400px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;font-size:13px;color:#fff;box-shadow:0 8px 24px #0000004d;animation:toast-in .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes toast-in{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.toast-success{background:#22c55ef2}.toast-error{background:#ef4444f2}.toast-warning{background:#f5a623f2}.toast-info{background:#4f8ef7f2}.toast-icon{width:22px;height:22px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.toast-message{flex:1;line-height:1.4}.toast-close{background:none;border:none;color:#ffffffb3;font-size:18px;cursor:pointer;padding:0 2px;flex-shrink:0}.toast-close:hover{color:#fff}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.confirm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:28px;width:100%;max-width:420px;box-shadow:0 12px 40px #00000080;animation:modal-pop .2s ease-out}@keyframes modal-pop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.confirm-title{font-size:18px;font-weight:700;color:var(--danger);margin-bottom:12px;display:flex;align-items:center;gap:8px}.confirm-message{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:16px}.confirm-input-label{font-size:12px;color:var(--text-muted);margin-bottom:6px}.confirm-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.notif-bell{position:relative;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:50%;transition:all .15s;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.notif-bell:hover{background:var(--bg-hover);color:var(--text-primary)}.notif-badge{position:absolute;top:0;right:0;background:var(--danger);color:#fff;font-size:9px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-secondary);animation:notif-pop .3s ease-out}@keyframes notif-pop{0%{transform:scale(0)}70%{transform:scale(1.2)}to{transform:scale(1)}}.notif-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:199}.notif-panel{position:absolute;top:calc(100% + 12px);right:0;width:380px;max-height:500px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px #00000080;z-index:200;overflow:hidden;display:flex;flex-direction:column;animation:dropdown-enter .15s ease-out}.notif-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border)}.notif-mark-read{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer}.notif-list{overflow-y:auto;flex:1}.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:#4f8ef70f}.notif-item.unread:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px}.notif-icon{font-size:16px;flex-shrink:0;margin-top:2px}.notif-content{flex:1;min-width:0}.notif-title{font-size:13px;font-weight:500;margin-bottom:2px}.notif-message{font-size:12px;color:var(--text-secondary);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-time{font-size:11px;color:var(--text-muted)}.kanban-board::-webkit-scrollbar{height:10px}.kanban-board::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:5px}.kanban-board::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}.kanban-board::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state p{font-size:14px}.feedback-fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:300;box-shadow:0 4px 16px #4f8ef766;transition:transform .2s,background .2s;animation:fab-pulse 2s ease-in-out 3}@keyframes fab-pulse{0%,to{box-shadow:0 4px 16px #4f8ef766}50%{box-shadow:0 4px 24px #4f8ef7b3,0 0 0 8px #4f8ef726}}.feedback-fab:hover{transform:scale(1.1);background:var(--accent-hover)}.feedback-badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;font-size:11px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.feedback-panel{position:fixed;bottom:88px;right:24px;width:400px;max-height:70vh;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;z-index:300;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006;overflow:hidden}.feedback-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.feedback-body{flex:1;overflow-y:auto;padding:16px 20px}.feedback-new-btn{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;margin-bottom:16px;transition:background .15s}.feedback-new-btn:hover{background:var(--accent-hover)}.feedback-list{display:flex;flex-direction:column;gap:8px}.feedback-item{padding:12px;background:var(--bg-input);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s;border:1px solid transparent}.feedback-item:hover{border-color:var(--accent)}.feedback-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.feedback-category{font-size:11px;font-weight:600;text-transform:uppercase}.feedback-status{font-size:10px;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:10px}.feedback-item-title{font-size:13px;font-weight:500;margin-bottom:4px}.feedback-item-meta{font-size:11px;color:var(--text-muted)}.feedback-back{background:none;border:none;color:var(--accent);font-size:13px;cursor:pointer;padding:0;margin-bottom:12px}.feedback-back:hover{text-decoration:underline}.feedback-categories{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:4px}.feedback-cat-btn{padding:8px;background:var(--bg-input);border:2px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:border-color .15s,color .15s}.feedback-cat-btn:hover{border-color:var(--border);color:var(--text-primary)}.feedback-cat-btn.active{border-color:var(--accent);color:var(--accent)}.feedback-form .form-textarea{min-height:120px}.feedback-detail-header{display:flex;justify-content:space-between;align-items:center}@media(max-width:768px){.feedback-panel{width:calc(100vw - 32px);right:16px;bottom:80px;max-height:80vh}.feedback-fab{bottom:16px;right:16px}}.page-content{animation:page-fade-in .25s ease-out}@keyframes page-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.shortcuts-trigger{display:flex;align-items:center;justify-content:center;gap:6px;background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:6px 8px;border-radius:var(--radius-sm);width:100%;margin-top:4px;transition:all .15s ease}.shortcuts-trigger:hover{background:var(--bg-hover);color:var(--text-primary)}.shortcuts-modal .modal{max-width:440px}.shortcuts-list{display:flex;flex-direction:column;gap:10px}.shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.shortcut-row:not(:last-child){border-bottom:1px solid var(--border);padding-bottom:10px}.shortcut-desc{font-size:13px;color:var(--text-secondary)}.shortcut-keys{display:flex;gap:4px}kbd{display:inline-block;padding:3px 8px;font-size:12px;font-family:inherit;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);box-shadow:0 1px 0 var(--border)}.stage-form-section{border:1.5px solid var(--accent);border-radius:var(--radius);background:linear-gradient(135deg,var(--bg-card),color-mix(in srgb,var(--accent) 5%,var(--bg-card)))}.stage-form-section .detail-card-header{border-bottom:1px solid color-mix(in srgb,var(--accent) 20%,var(--border))}.stage-form-status{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px}.stage-form-status.complete{background:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success)}.stage-form-status.incomplete{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.stage-form-fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:4px 0}.stage-form-field{display:flex;flex-direction:column;gap:4px}.stage-form-field.full-width{grid-column:1 / -1}.stage-form-label{font-size:12px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.required-star{color:var(--danger);font-weight:700;font-size:14px}.readonly-badge{font-size:9px;padding:1px 5px;border-radius:3px;background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning);font-weight:700;letter-spacing:.5px}.stage-form-locked-value{padding:8px 10px;background:var(--bg-input);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;min-height:36px;display:flex;align-items:center}.stage-form-input{font-size:13px}.stage-form-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:480px;max-width:94vw;max-height:85vh;overflow-y:auto;animation:modalSlideUp .25s ease}.stage-form-modal-header{display:flex;align-items:flex-start;gap:12px;padding:18px 20px 12px;border-bottom:1px solid var(--border)}.stage-form-modal-header h3{font-size:16px;color:var(--text-primary)}.stage-form-modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}.stage-form-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px 16px;border-top:1px solid var(--border)}.card-form-badge{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:600;padding:1px 6px;border-radius:3px;background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.stage-attachment-list{display:flex;flex-direction:column;gap:6px}.stage-attachment-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px}.stage-attachment-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--accent);text-decoration:none}.stage-attachment-name:hover{text-decoration:underline}.stage-attachment-meta{font-size:11px;color:var(--text-muted);white-space:nowrap}.stage-attachment-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:3px;display:flex;align-items:center;transition:all .15s}.stage-attachment-delete:hover{color:var(--danger);background:color-mix(in srgb,var(--danger) 10%,transparent)}.stage-attachment-upload-btn{cursor:pointer;display:inline-flex;align-items:center;gap:5px;margin-top:6px}.file-preview-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:90vw;max-width:900px;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideUp .25s ease}.file-preview-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);gap:12px}.file-preview-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-body{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:16px;min-height:300px;background:var(--bg-secondary)}.file-preview-image{max-width:100%;max-height:70vh;border-radius:var(--radius-sm);object-fit:contain}.file-preview-pdf{width:100%;height:70vh;border:none;border-radius:var(--radius-sm)}.file-preview-unsupported{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);padding:40px}.file-preview-unsupported p{font-size:14px}.upload-hint{font-size:10px;color:var(--text-muted);margin-top:4px;letter-spacing:.2px}.stage-form-previous{border-color:var(--border)!important;background:var(--bg-card)!important;opacity:.85}.stage-form-previous .detail-card-header{border-bottom-color:var(--border)!important}.editable-cell{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:4px;cursor:pointer;transition:background .15s}.editable-cell:hover{background:var(--bg-hover)}.editable-cell-icon{opacity:0;color:var(--text-muted);transition:opacity .15s}.editable-cell:hover .editable-cell-icon{opacity:1}.editable-cell-edit{display:inline-flex;align-items:center;gap:4px}.editable-cell-input{padding:4px 8px!important;font-size:13px;min-width:120px}.editable-cell-btn{border:none;padding:4px 6px;border-radius:3px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.editable-cell-btn.save{background:var(--success);color:#fff}.editable-cell-btn.save:hover{background:color-mix(in srgb,var(--success) 85%,black)}.editable-cell-btn.cancel{background:var(--bg-input);color:var(--text-secondary)}.editable-cell-btn.cancel:hover{background:var(--bg-hover)}.print-page{max-width:820px;margin:0 auto;padding:32px 40px;background:#fff;color:#1a1a1a;font-family:-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:13px;line-height:1.5;min-height:100vh}.print-controls{display:flex;gap:8px;justify-content:flex-end;margin-bottom:20px;padding:10px;background:#f5f5f5;border-radius:6px;position:sticky;top:0;z-index:10}.print-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:18px;border-bottom:2px solid #1a1a1a;margin-bottom:24px}.print-logo{height:56px;width:auto;object-fit:contain}.print-header-right{text-align:right}.print-doc-title{font-size:18px;font-weight:800;color:#1a1a1a;letter-spacing:.5px;text-transform:uppercase}.print-doc-meta{font-size:11px;color:#666;margin-top:4px}.print-ticket-summary{margin-bottom:24px}.print-ticket-title{font-size:22px;font-weight:700;color:#1a1a1a;margin:0 0 14px;padding-bottom:8px;border-bottom:1px solid #e5e5e5}.print-meta-table{width:100%;border-collapse:collapse;font-size:12px}.print-meta-table th{text-align:left;padding:6px 10px;background:#f5f5f5;color:#555;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.5px;width:14%;border:1px solid #e5e5e5}.print-meta-table td{padding:6px 10px;color:#1a1a1a;width:36%;border:1px solid #e5e5e5}.print-priority{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase}.print-section{margin-bottom:24px;page-break-inside:avoid}.print-section-title{font-size:14px;font-weight:700;color:#1a1a1a;margin:0 0 10px;padding-bottom:6px;border-bottom:1.5px solid #d2b16b;display:flex;align-items:center;gap:8px}.print-stage-dot{width:12px;height:12px;border-radius:3px;display:inline-block}.print-stage-current{font-size:10px;color:#4f8ef7;font-weight:600;letter-spacing:.5px}.print-description{margin:0;padding:10px 14px;background:#fafafa;border-left:3px solid #d2b16b;white-space:pre-wrap;color:#333}.print-fields-table{width:100%;border-collapse:collapse;font-size:12px}.print-fields-table th{text-align:left;padding:8px 12px;background:#fafafa;color:#555;font-weight:600;width:30%;border:1px solid #e5e5e5;vertical-align:top}.print-fields-table td{padding:8px 12px;color:#1a1a1a;border:1px solid #e5e5e5;vertical-align:top}.print-attachment-list{margin:0;padding-left:18px}.print-attachment-list li{margin:2px 0;color:#333}.print-comment{padding:10px 14px;background:#fafafa;border-left:3px solid #4f8ef7;margin-bottom:8px;page-break-inside:avoid}.print-comment-header{display:flex;justify-content:space-between;margin-bottom:4px;font-size:11px}.print-comment-header strong{color:#1a1a1a}.print-comment-header span{color:#888}.print-comment-body{color:#333;white-space:pre-wrap}.print-footer{margin-top:40px;padding-top:12px;border-top:1px solid #e5e5e5;display:flex;justify-content:space-between;font-size:10px;color:#888}@media print{body{background:#fff!important}.no-print{display:none!important}.print-page{padding:12mm 16mm;max-width:none;background:#fff!important;color:#1a1a1a!important;min-height:auto}.print-section{page-break-inside:avoid}.print-header,.print-section-title,.print-ticket-title{page-break-after:avoid}@page{size:A4;margin:0}}.multiselect-list{display:flex;flex-wrap:wrap;gap:4px 0;padding:6px 0}.mention-dropdown{position:absolute;bottom:calc(100% + 4px);left:0;right:0;max-width:320px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;max-height:240px;overflow-y:auto}.mention-dropdown-header{display:flex;align-items:center;gap:4px;padding:6px 12px;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-input)}.mention-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s}.mention-item:hover,.mention-item.active{background:color-mix(in srgb,var(--accent) 15%,transparent)}.mention-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mention-name{font-size:13px;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-username{font-size:11px;color:var(--text-muted)}.mention-tag{color:var(--accent);font-weight:600;background:color-mix(in srgb,var(--accent) 12%,transparent);padding:1px 4px;border-radius:3px}.quick-filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:8px}.quick-filter-widget{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--radius);cursor:pointer;transition:all .2s}.quick-filter-widget:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}.quick-filter-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-filter-content{flex:1;min-width:0}.quick-filter-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.quick-filter-count{font-size:24px;font-weight:800;color:var(--text-primary);line-height:1}.notif-item{position:relative}.notif-delete-btn{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:3px;opacity:0;transition:all .15s}.notif-item:hover .notif-delete-btn{opacity:1}.notif-delete-btn:hover{color:var(--danger);background:color-mix(in srgb,var(--danger) 12%,transparent)}.members-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:460px;max-width:94vw;max-height:80vh;display:flex;flex-direction:column;animation:modalSlideUp .25s ease}.members-modal-header{display:flex;align-items:flex-start;gap:12px;padding:18px 20px 12px;border-bottom:1px solid var(--border)}.members-modal-header h3{font-size:16px;color:var(--text-primary)}.members-modal-body{flex:1;overflow-y:auto;padding:8px 4px;max-height:480px}.members-modal-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:default;border-radius:var(--radius-sm);margin:2px 8px;transition:background .1s}.members-modal-item:hover{background:var(--bg-hover)}.logo-wrap{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.sidebar-logo-icon{width:28px;height:28px;flex-shrink:0;border-radius:6px}.logo-subtitle{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-top:1px;font-weight:500}.brand-meaning{margin:18px 0 22px;padding:14px 18px;background:#ffffff0d;border-left:3px solid #4f8ef7;border-radius:6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.brand-meaning-row{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}.brand-meaning-row:last-of-type{margin-bottom:10px}.brand-word{font-size:18px;font-weight:800;color:#fff;font-family:Inter,sans-serif;min-width:64px}.brand-meaning-text{font-size:13px;color:#ffffffbf;letter-spacing:.2px}.brand-meaning-tagline{font-size:12px;color:#fff9;padding-top:8px;border-top:1px solid rgba(255,255,255,.08);letter-spacing:.3px}.logo-tagline{font-size:9px;font-weight:600;color:var(--accent);letter-spacing:.6px;margin-top:2px;text-transform:uppercase;white-space:nowrap}.logo-tagline span{color:var(--accent)}.login-flex-tagline{font-size:10px;font-weight:600;color:var(--accent);letter-spacing:1px;text-transform:uppercase;margin-top:-8px;margin-bottom:4px;text-align:center}.login-flex-tagline span{color:var(--accent)}
