.gs-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:500;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh}.gs-dialog{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay);width:100%;max-width:560px;overflow:hidden}.gs-input{width:100%;padding:16px 20px;border:none;font-size:16px;font-family:inherit;outline:none;background:var(--color-surface);color:var(--color-text);border-bottom:1px solid var(--color-border)}.gs-results{max-height:350px;overflow-y:auto}.gs-item{display:flex;align-items:center;gap:10px;padding:10px 20px;cursor:pointer;font-size:14px}.gs-item:hover,.gs-item.active{background:var(--color-primary-light)}.gs-id{font-size:12px;color:var(--color-text-subtle);flex-shrink:0}.gs-subject{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gs-project{font-size:11px;color:var(--color-text-subtle);flex-shrink:0}.gs-empty,.gs-hint{padding:24px;text-align:center;color:var(--color-text-subtle);font-size:14px}.gs-footer{display:flex;gap:16px;padding:8px 20px;background:var(--color-bg);font-size:11px;color:var(--color-text-subtle);border-top:1px solid var(--color-border)}@media (max-width: 600px){.gs-dialog{max-width:95%;margin:0 10px}.gs-overlay{padding-top:10vh}}.hk-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:500;display:flex;align-items:center;justify-content:center}.hk-dialog{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay);width:100%;max-width:400px;overflow:hidden}.hk-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border)}.hk-header h2{font-size:18px}.hk-list{padding:12px 20px}.hk-item{display:flex;align-items:center;gap:16px;padding:8px 0;border-bottom:1px solid var(--color-border)}.hk-item:last-child{border-bottom:none}.hk-kbd{background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;padding:3px 8px;font-family:monospace;font-size:12px;font-weight:600;min-width:60px;text-align:center;box-shadow:0 1px 0 var(--color-border)}.ob-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:9000;display:flex;align-items:center;justify-content:center}.ob-dialog{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay);padding:40px;width:100%;max-width:440px;text-align:center;position:relative}.ob-icon{font-size:48px;margin-bottom:16px}.ob-title{font-size:22px;font-weight:700;margin-bottom:12px}.ob-content{font-size:15px;color:var(--color-text-subtle);line-height:1.6;margin-bottom:24px}.ob-dots{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.ob-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border)}.ob-dot.active{background:var(--color-primary);width:24px;border-radius:4px}.ob-actions{display:flex;gap:12px;justify-content:center}.ob-actions .btn{min-width:120px;padding:10px 20px}.feedback-menu-btn.sidebar-menu-item{display:flex!important;align-items:center;gap:8px}.feedback-menu-btn svg{flex-shrink:0;opacity:.6}.feedback-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#091e428a;z-index:300;display:flex;align-items:center;justify-content:center;padding:16px}.feedback-modal{max-width:560px;width:100%;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay)}.feedback-hint{font-size:13px;color:var(--color-text-subtle);margin-bottom:16px;line-height:1.5}.feedback-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px;text-align:center;font-size:16px;color:var(--color-success)}.feedback-success-icon{width:48px;height:48px;border-radius:50%;background:var(--color-success);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.feedback-editor-wrap{border:2px solid var(--color-border);border-radius:var(--radius);transition:border-color .15s;overflow:hidden}.feedback-editor-wrap:focus-within{border-color:var(--color-primary)}.feedback-editor{min-height:120px;max-height:300px;overflow-y:auto;padding:10px 12px;font-size:14px;line-height:1.6;outline:none;word-break:break-word}.feedback-editor:empty:before{content:attr(data-placeholder);color:var(--color-text-subtle);pointer-events:none}.feedback-editor img{max-width:100%;border-radius:4px;margin:8px 0;display:block}.feedback-editor-toolbar{display:flex;align-items:center;gap:4px;padding:6px 8px;border-top:1px solid var(--color-border);background:var(--color-bg)}.feedback-attach-btn,.feedback-screenshot-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:1px solid var(--color-border);border-radius:var(--radius);padding:4px 8px;font-size:12px;color:var(--color-text-subtle);cursor:pointer;transition:all .15s}.feedback-attach-btn:hover,.feedback-screenshot-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.feedback-uploading{font-size:12px;color:var(--color-primary);margin-left:auto}.online-users{display:flex;align-items:center;gap:4px}.online-users-avatars{display:flex;align-items:center}.online-user-avatar{position:relative;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;border:2px solid #FFFFFF;margin-left:-6px;cursor:default}.online-user-avatar:first-child{margin-left:0}.online-user-avatar:nth-child(1){background:#3b82f6}.online-user-avatar:nth-child(2){background:#10b981}.online-user-avatar:nth-child(3){background:#f59e0b}.online-user-avatar:nth-child(4){background:#8b5cf6}.online-user-avatar:nth-child(5){background:#ec4899}.online-user-initial{line-height:1}.online-user-dot{position:absolute;bottom:-1px;right:-1px;width:7px;height:7px;border-radius:50%;background:#10b981;border:1.5px solid #FFFFFF}.online-user-more{font-size:9px;font-weight:700;color:#6b7280;background:#f3f4f6}.layout{display:flex;height:100vh;overflow:hidden}.layout-body{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg)}.sidebar{width:220px;flex-shrink:0;background:var(--color-surface, #FFFFFF);border-right:1px solid var(--color-border, #E8EAED);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow-y:auto;overflow-x:hidden}.sidebar-logo{display:flex;align-items:center;gap:8px;padding:0 16px;height:64px;flex-shrink:0}.sidebar-logo-texts{display:flex;flex-direction:column;gap:1px}.sidebar-logo-title{font-size:14px;font-weight:700;color:var(--color-text, #111827);line-height:1.2}.sidebar-logo-subtitle{font-size:10px;color:var(--color-text-muted, #6B7280);font-weight:400;line-height:1.2}.sidebar-logo-icon{width:28px;height:28px;border-radius:6px;background:var(--color-primary, #4A9FD8);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.sidebar-divider{height:1px;background:#f3f4f6;flex-shrink:0;margin:0}.sidebar-section-label{font-size:10px;font-weight:700;color:#000;letter-spacing:.06em;padding:8px 16px 4px}.sidebar-section{padding:8px 0}.sidebar-portfolio-header{display:flex;align-items:center;gap:0}.sidebar-portfolio-header .sidebar-portfolio-group{flex:1}.sidebar-portfolio-settings{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:none;cursor:pointer;color:#9ca3af;border-radius:4px;margin-right:6px;opacity:0;transition:opacity .15s,background .12s,color .12s;flex-shrink:0}.sidebar-portfolio-header:hover .sidebar-portfolio-settings{opacity:1}.sidebar-portfolio-settings:hover{background:#e5e7eb;color:#374151}.sidebar-portfolio-group{display:flex;align-items:center;gap:7px;width:100%;padding:5px 12px 5px 14px;border:none;background:none;cursor:pointer;font-family:inherit;color:#6b7280;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;text-align:left;transition:background .12s;border-radius:4px;margin:2px 4px 0}.sidebar-portfolio-group:hover{background:#f3f4f6;color:#374151}.sidebar-portfolio-icon{display:inline-block;width:10px;height:10px;border-radius:3px;flex-shrink:0}.sidebar-portfolio-name{flex:1}.sidebar-portfolio-count{background:#f3f4f6;color:#9ca3af;font-size:10px;font-weight:600;padding:0 5px;border-radius:8px;letter-spacing:0;text-transform:none;min-width:18px;text-align:center}.sidebar-project-picker{position:relative}.sidebar-project-btn{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;border:none;background:transparent;cursor:pointer;font-size:13px;font-family:inherit;color:var(--color-text, #111827);transition:background .15s;text-align:left;height:34px}.sidebar-project-btn:hover{background:var(--color-border-light, #F3F4F6)}.sidebar-project-btn--static{cursor:default}.sidebar-project-btn--static:hover{background:transparent}.sidebar-project-dot{width:8px;height:8px;border-radius:4px;background:var(--color-primary, #4A9FD8);flex-shrink:0}.sidebar-project-name{flex:1;font-size:13px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text, #111827)}.sidebar-project-chevron{color:#6b7280;flex-shrink:0}.sidebar-project-menu{position:absolute;left:8px;right:8px;top:calc(100% + 4px);background:var(--color-surface, #FFFFFF);border:1px solid var(--color-border, #E8EAED);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:200;overflow:hidden}.sidebar-project-item{display:block;width:100%;padding:8px 12px;text-align:left;border:none;background:transparent;font-size:13px;font-family:inherit;color:var(--color-text, #111827);cursor:pointer;transition:background .15s}.sidebar-project-item:hover{background:var(--color-bg, #F0F2F5)}.sidebar-project-item.active{color:var(--color-primary, #4A9FD8);font-weight:600}.sidebar-project-list{display:flex;flex-direction:column;padding:2px 0}.sidebar-project-row{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;border:none;background:transparent;cursor:pointer;font-size:13px;font-family:inherit;color:var(--color-text-muted, #6B7280);transition:background .15s,color .15s;text-align:left;height:34px}.sidebar-project-row:hover{background:var(--color-border-light, #F3F4F6);color:var(--color-text, #111827)}.sidebar-project-row.active{color:var(--color-text, #111827);font-weight:500;cursor:default}.sidebar-project-row.active:hover{background:transparent}.sidebar-project-row.indented{padding-left:28px}.sidebar-project-row--archived{opacity:.55}.sidebar-project-wrap{display:flex;align-items:center;position:relative}.sidebar-project-wrap>.sidebar-project-row{flex:1}.sidebar-drag-handle{color:#c4c9d4;cursor:grab;flex-shrink:0;margin-left:4px;opacity:0;transition:opacity .15s}.sidebar-project-wrap:hover .sidebar-drag-handle{opacity:1}.sidebar-project-wrap.drag-over{border-top:2px solid var(--color-primary)}.sidebar-pin-icon{color:#f59e0b;flex-shrink:0;margin-left:auto}.sidebar-project-pin-btn{background:none;border:none;padding:3px;cursor:pointer;color:#c4c9d4;border-radius:4px;display:flex;align-items:center;opacity:0;transition:opacity .15s,color .1s;flex-shrink:0}.sidebar-project-wrap:hover .sidebar-project-pin-btn{opacity:1}.sidebar-project-pin-btn.active{color:#f59e0b;opacity:1}.sidebar-project-pin-btn:hover{color:#f59e0b}.sidebar-archive-section{padding:0 8px;margin-top:4px}.sidebar-archive-toggle{display:flex;align-items:center;gap:5px;width:100%;background:none;border:none;padding:5px 4px;color:#9ca3af;font-size:11px;font-weight:600;letter-spacing:.04em;cursor:pointer;border-radius:4px;transition:color .15s,background .15s}.sidebar-archive-toggle:hover{color:#374151;background:#f3f4f6}.sidebar-nav{padding:0 8px 8px;display:flex;flex-direction:column;gap:2px}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:0 8px;height:36px;border-radius:8px;font-size:13px;font-weight:400;color:#666;text-decoration:none;transition:background .15s,color .15s;position:relative}.sidebar-nav-item svg{color:#888;flex-shrink:0;transition:color .15s}.sidebar-nav-item:hover{background:var(--color-bg, #F0F2F5);color:var(--color-text, #111827);text-decoration:none}.sidebar-nav-item:hover svg{color:var(--color-text, #111827)}.sidebar-nav-item.active{background:#1a1a1a;color:#fff;font-weight:600}.sidebar-nav-item.active svg{color:#fff}.sidebar-badge{margin-left:auto;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.sidebar-spacer{flex:1}.sidebar-online{padding:8px 0}.sidebar-online .sidebar-section-label{padding:0 16px;height:26px;display:flex;align-items:center}.sidebar-online .online-users{padding:0 16px;height:34px;display:flex;align-items:center}.sidebar-user{position:relative;flex-shrink:0}.sidebar-user-btn{display:flex;align-items:center;gap:8px;width:100%;padding:0 16px;height:58px;border:none;background:var(--color-surface-2, #F9FAFB);cursor:pointer;font-family:inherit;text-align:left;transition:background .15s;border-top:1px solid #F3F4F6}.sidebar-user-btn:hover{background:var(--color-border-light, #F3F4F6)}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary, #4A9FD8);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.sidebar-user-name{font-size:12px;font-weight:600;color:var(--color-text, #111827);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:10px;color:#6b7280;font-weight:400}.sidebar-logout-icon{color:#9ca3af;flex-shrink:0;transition:color .15s;cursor:pointer}.sidebar-logout-icon:hover{color:#ef4444}.sidebar-user-menu{position:absolute;bottom:calc(100% + 4px);left:8px;right:8px;background:var(--color-surface, #FFFFFF);border:1px solid var(--color-border, #E8EAED);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:200;overflow:hidden}.sidebar-user-menu-header{padding:10px 14px;border-bottom:1px solid var(--color-border, #E8EAED)}.sidebar-user-menu-header strong{display:block;font-size:13px;color:var(--color-text, #111827);margin-bottom:2px}.sidebar-user-name-editable{cursor:pointer;border-radius:4px;padding:1px 4px;margin:-1px -4px;transition:background .15s}.sidebar-user-name-editable:hover{background:#f3f4f6}.sidebar-edit-name{display:flex;flex-direction:column;gap:6px;margin-bottom:2px}.sidebar-edit-name-input{width:100%;height:32px;padding:0 10px;font-size:13px;font-weight:600;border:1.5px solid #4A9FD8;border-radius:6px;outline:none;color:#111827;background:#fff;box-sizing:border-box}.sidebar-edit-name-btns{display:flex;gap:6px}.sidebar-edit-name-ok,.sidebar-edit-name-cancel{flex:1;height:30px;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;font-family:inherit}.sidebar-edit-name-ok{color:#fff;background:#1a1a1a}.sidebar-edit-name-ok:hover{background:#333}.sidebar-edit-name-cancel{color:#666;background:#f3f4f6;border:1px solid #E8EAED}.sidebar-edit-name-cancel:hover{background:#e8eaed}.sidebar-user-menu-header span{font-size:11px;color:var(--color-text-subtle, #9CA3AF)}.sidebar-menu-item{display:block;width:100%;padding:8px 14px;text-align:left;border:none;background:transparent;font-size:13px;font-family:inherit;color:var(--color-text, #111827);cursor:pointer;text-decoration:none;transition:background .15s}.sidebar-menu-item:hover{background:var(--color-bg, #F0F2F5);text-decoration:none}.sidebar-menu-item.active{color:var(--color-primary, #4A9FD8);font-weight:600}.sidebar-menu-item--danger{color:#ef4444}.sidebar-menu-divider{height:1px;background:var(--color-border, #E8EAED);margin:4px 0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:0 12px;height:36px;border:none;border-radius:var(--radius, 8px);font-size:13px;font-weight:500;transition:background .15s;cursor:pointer;gap:6px;font-family:inherit;white-space:nowrap}.btn-primary{background:var(--color-primary, #4A9FD8);color:#fff}.btn-primary:hover{background:var(--color-primary-hover, #3A8FC8)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-subtle{background:transparent;color:inherit}.btn-subtle:hover{background:#0000000f}.btn-default{background:var(--btn-default-bg, #F7F8FA);color:var(--color-text, #111827);border:1px solid var(--btn-default-border, #E8EAED)}.btn-default:hover{background:var(--color-border, #E8EAED)}.btn-warning{background:#ede9fe;color:#8b5cf6;border:1px solid #C4B5FD}.btn-warning:hover{background:#ddd6fe}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{height:28px;padding:0 8px;font-size:12px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius, 8px);background:transparent;color:var(--color-text-subtle, #9CA3AF);cursor:pointer;transition:background .15s,color .15s}.btn-icon:hover{background:var(--color-bg, #F0F2F5);color:var(--color-primary, #4A9FD8)}.btn-icon-danger:hover{background:#fef2f2;color:#ef4444}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--color-text-subtle, #9CA3AF);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.form-input{width:100%;padding:8px 10px;border:1px solid var(--input-border, #E8EAED);border-radius:var(--radius, 8px);font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none;background:var(--input-bg, #FFFFFF);color:var(--color-text, #111827)}.form-input:focus{border-color:var(--input-focus, #4A9FD8);box-shadow:0 0 0 2px #4a9fd826}.form-select{width:100%;padding:8px 10px;border:1px solid var(--input-border, #E8EAED);border-radius:var(--radius, 8px);font-size:14px;font-family:inherit;background:var(--input-bg, #FFFFFF);color:var(--color-text, #111827);outline:none}.form-select:focus{border-color:var(--input-focus, #4A9FD8)}.badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-blue{background:#ebf5fb;color:#4a9fd8}.badge-green{background:#ecfdf5;color:#10b981}.badge-purple{background:#f5f3ff;color:#8b5cf6}.badge-teal{background:#f0fdf9;color:#14b8a6}.badge-yellow{background:#fffbeb;color:#f59e0b}.badge-red{background:#fef2f2;color:#ef4444}.badge-default{background:#f3f4f6;color:#6b7280}.card{background:var(--color-surface, #FFFFFF);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-card);padding:20px}.error-msg{color:#ef4444;font-size:13px;margin-top:8px}.no-project-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.no-project-card{text-align:center;padding:48px;max-width:460px;width:100%}.no-project-card h1{font-size:24px;margin-bottom:8px}.create-project-inline{text-align:left;max-width:320px;margin:0 auto}.changelog-modal{max-width:560px}.changelog-entry{margin-bottom:20px}.changelog-version-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.changelog-version{font-size:18px;font-weight:700;color:var(--color-primary);font-family:monospace}.changelog-date{font-size:13px;color:var(--color-text-subtle)}.changelog-list{padding-left:20px;font-size:14px;line-height:1.7}.changelog-list li{margin-bottom:2px}@media (max-width: 768px){.sidebar{display:none}.main-content{padding:12px}}.auth-page{min-height:100vh;display:flex;background:var(--color-bg, #F0F2F5)}.auth-left{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1a1a1a;padding:48px;min-width:0}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}.auth-brand-icon{width:64px;height:64px;border-radius:16px;background:var(--color-primary, #4A9FD8);display:flex;align-items:center;justify-content:center;color:#fff}.auth-brand-title{font-size:32px;font-weight:700;color:#fff;letter-spacing:-.02em}.auth-brand-subtitle{font-size:15px;color:#9ca3af;line-height:1.5;max-width:280px}.auth-right{width:480px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:48px;background:#fff;border-left:1px solid var(--color-border, #E8EAED)}.auth-form-wrap{width:100%;max-width:360px}.auth-form-title{font-size:22px;font-weight:700;color:var(--color-text, #111827);margin-bottom:8px}.auth-form-subtitle{font-size:14px;color:var(--color-text-muted, #6B7280);margin-bottom:32px}.auth-form-wrap .form-group{margin-bottom:16px}.auth-form-wrap .form-label{font-size:13px;font-weight:500;color:var(--color-text, #111827);text-transform:none;letter-spacing:0;margin-bottom:6px}.auth-form-wrap .form-input{height:42px;font-size:14px;border:1px solid var(--color-border, #E8EAED);border-radius:8px;padding:0 12px;transition:border-color .15s,box-shadow .15s}.auth-form-wrap .form-input:focus{border-color:var(--color-primary, #4A9FD8);box-shadow:0 0 0 3px #4a9fd826}.auth-btn{width:100%;height:44px;margin-top:8px;font-size:15px;font-weight:600;border-radius:8px}.auth-link{text-align:center;margin-top:20px;font-size:14px;color:var(--color-text-muted, #6B7280)}.auth-link a{color:var(--color-primary, #4A9FD8);font-weight:500}.auth-link a:hover{text-decoration:underline}@media (max-width: 768px){.auth-page{flex-direction:column}.auth-left{padding:32px 24px;min-height:200px}.auth-brand-title{font-size:24px}.auth-brand-subtitle{display:none}.auth-right{width:100%;border-left:none;border-top:1px solid var(--color-border);padding:32px 24px}}.fibonacci-selector{display:flex;gap:4px}.fib-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.fib-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.fib-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.fibonacci-selector.disabled .fib-btn{opacity:.5;cursor:not-allowed}.fibonacci-selector.disabled .fib-btn:hover{border-color:var(--color-border);color:var(--color-text)}.rte-container{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.rte-container:focus-within{border-color:var(--color-primary)}.rte-readonly{border:none}.rte-toolbar{display:flex;gap:2px;padding:4px;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.rte-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius);background:transparent;color:var(--color-text-subtle);font-size:13px;cursor:pointer}.rte-btn:hover{background:var(--color-border);color:var(--color-text)}.rte-btn.active{background:var(--color-primary);color:var(--color-text-inverse)}.rte-content .tiptap{padding:8px 12px;min-height:80px;font-size:14px;line-height:1.6;outline:none}.rte-minimal .rte-content .tiptap{min-height:40px}.rte-content .tiptap p{margin:0 0 8px}.rte-content .tiptap p:last-child{margin-bottom:0}.rte-content .tiptap img{max-width:100%;border-radius:var(--radius);margin:8px 0}.rte-content .tiptap h3{font-size:16px;margin:12px 0 4px}.rte-content .tiptap ul,.rte-content .tiptap ol{padding-left:20px;margin:4px 0}.rte-content .tiptap code{background:var(--color-bg);padding:2px 4px;border-radius:2px;font-size:13px}.rte-content .tiptap pre{background:var(--color-bg);padding:12px;border-radius:var(--radius);overflow-x:auto;margin:8px 0}.rte-content .tiptap .is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--color-text-subtle);pointer-events:none;height:0}.rte-display{font-size:14px;line-height:1.6}.rte-display p{margin:0 0 8px}.rte-display img{max-width:100%;border-radius:var(--radius);margin:8px 0}.rte-display h3{font-size:16px;margin:12px 0 4px}.rte-display ul,.rte-display ol{padding-left:20px}.rte-display code{background:var(--color-bg);padding:2px 4px;border-radius:2px}.rte-display pre{background:var(--color-bg);padding:12px;border-radius:var(--radius);overflow-x:auto}.rte-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000e0;display:flex;align-items:center;justify-content:center;overflow:hidden;-webkit-user-select:none;user-select:none}.rte-lightbox-img{max-width:90vw;max-height:85vh;border-radius:6px;box-shadow:0 8px 48px #0009;object-fit:contain;pointer-events:none;transform-origin:center center;transition:transform .05s linear}.rte-lightbox-toolbar{position:absolute;top:18px;right:22px;display:flex;align-items:center;gap:4px;z-index:1}.rte-lb-btn{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;background:#ffffff24;border:1px solid rgba(255,255,255,.18);border-radius:7px;color:#fff;font-size:18px;line-height:1;cursor:pointer;transition:background .15s}.rte-lb-btn:hover{background:#ffffff47}.rte-lb-close{font-size:22px;min-width:36px}.rte-lb-zoom{font-size:12px;color:#ffffffb3;min-width:42px;text-align:center;font-variant-numeric:tabular-nums}.msg-input-wrap{display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:4px;transition:border-color .15s}.msg-input-wrap:focus-within{border-color:var(--color-primary)}.msg-input-row{display:flex;align-items:flex-end}.msg-attach-btn{background:none;border:none;color:var(--color-text-subtle);cursor:pointer;padding:8px;border-radius:50%;transition:color .15s;flex-shrink:0}.msg-attach-btn:hover{color:var(--color-primary)}.msg-input-field-wrap{flex:1;position:relative}.msg-input-field{min-height:24px;max-height:120px;overflow-y:auto;padding:8px 4px;font-size:14px;line-height:1.5;outline:none;word-break:break-word}.msg-input-field:empty:before{content:attr(data-placeholder);color:var(--color-text-subtle);pointer-events:none}.msg-mention-dropdown{position:absolute;bottom:100%;left:0;right:0;background:#fff;border:1px solid #E8EAED;border-radius:8px;box-shadow:0 -4px 16px #0000001a;max-height:200px;overflow-y:auto;z-index:50;margin-bottom:4px}.msg-mention-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;transition:background .1s}.msg-mention-item:hover,.msg-mention-item.active{background:#ebf5fb}.msg-mention-name{font-size:13px;font-weight:500;color:#1a1a1a}.msg-mention-login{font-size:11px;color:#4a9fd8}.msg-send-btn{background:none;border:none;color:var(--color-border);cursor:pointer;padding:8px;border-radius:50%;transition:all .15s;flex-shrink:0}.msg-send-btn.active{color:var(--color-primary)}.msg-send-btn.active:hover{background:var(--color-primary-light)}.msg-uploading{font-size:12px;color:var(--color-text-subtle);padding:8px 4px;flex-shrink:0}.msg-attachments{display:flex;gap:8px;flex-wrap:wrap;padding:8px 8px 4px}.msg-attach-preview{position:relative;display:inline-flex;align-items:center}.msg-attach-thumb{max-width:120px;max-height:80px;border-radius:6px;object-fit:cover}.msg-attach-file{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);font-size:12px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-attach-delete{position:absolute;top:-4px;right:-4px;width:20px;height:20px;border-radius:50%;border:none;background:#000000a6;color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s}.msg-attach-delete:hover{background:var(--color-danger, #de350b)}.msg-file-link{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text);font-size:13px;margin:4px 0;transition:background .15s}.msg-file-link:hover{background:var(--color-primary-light)}.msg-file-icon{font-size:18px}.msg-file-name{font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-file-size{color:var(--color-text-subtle);font-size:11px}.reactions-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-top:4px}.reaction-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid var(--color-border);border-radius:12px;background:var(--color-bg);cursor:pointer;font-size:13px;font-family:inherit;transition:background .15s,border-color .15s}.reaction-chip:hover,.reaction-chip.active{background:var(--color-primary-light);border-color:var(--color-primary)}.reaction-emoji{font-size:14px;line-height:1}.reaction-count{font-size:12px;font-weight:600;color:var(--color-text-subtle)}.reaction-chip.active .reaction-count{color:var(--color-primary)}.reaction-picker-wrap{position:relative}.reaction-add-btn{width:26px;height:26px;border-radius:50%;border:1px dashed var(--color-border);background:none;cursor:pointer;font-size:14px;color:var(--color-text-subtle);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.reaction-add-btn:hover{background:var(--color-bg);color:var(--color-text)}.reaction-picker{position:absolute;bottom:100%;left:0;margin-bottom:4px;display:flex;gap:2px;padding:4px 6px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay);z-index:50}.reaction-picker-item{width:32px;height:32px;border:none;background:none;cursor:pointer;font-size:18px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:background .1s}.reaction-picker-item:hover{background:var(--color-bg)}.checklist{margin-top:4px}.checklist-progress{margin-bottom:12px}.checklist-progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.checklist-progress-text,.checklist-progress-pct{font-size:12px;font-weight:600;color:var(--color-text-subtle)}.checklist-progress-bar{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.checklist-progress-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.checklist-progress-fill.complete{background:var(--color-success, #00875A)}.checklist-items{display:flex;flex-direction:column}.checklist-item{display:flex;align-items:center;gap:8px;padding:6px 4px;border-radius:var(--radius);transition:background .1s}.checklist-item:hover{background:var(--color-bg)}.checklist-item:hover .checklist-delete-btn{opacity:1}.checklist-checkbox-wrap{display:flex;align-items:center;cursor:pointer;flex-shrink:0}.checklist-checkbox{position:absolute;opacity:0;width:0;height:0}.checklist-checkmark{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:2px solid var(--color-border);border-radius:3px;background:var(--color-surface);transition:all .15s}.checklist-checkbox:checked+.checklist-checkmark{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.checklist-item-text{flex:1;font-size:14px;color:var(--color-text);cursor:pointer;padding:2px 4px;border-radius:var(--radius);line-height:1.4;word-break:break-word}.checklist-item-text:hover{background:var(--color-column-bg, rgba(0,0,0,.04))}.checklist-item.checked .checklist-item-text{text-decoration:line-through;color:var(--color-text-subtle)}.checklist-edit-input{flex:1;font-size:14px;padding:4px 8px;border:2px solid var(--color-primary);border-radius:var(--radius);outline:none;font-family:inherit;background:var(--color-surface);color:var(--color-text)}.checklist-delete-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;color:var(--color-text-subtle);cursor:pointer;border-radius:var(--radius);opacity:0;transition:opacity .15s,color .15s,background .15s;flex-shrink:0}.checklist-delete-btn:hover{color:var(--color-danger);background:#ffebe6}.checklist-add{display:flex;gap:6px;margin-top:8px}.checklist-add-input{flex:1;font-size:13px;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);outline:none;font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color .15s}.checklist-add-input:focus{border-color:var(--color-primary)}.checklist-add-input::placeholder{color:var(--color-text-subtle)}.checklist-add-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius);background:var(--color-primary);color:var(--color-text-inverse, #fff);cursor:pointer;flex-shrink:0;transition:background .15s}.checklist-add-btn:hover{background:var(--color-primary-hover)}.checklist-add-btn:disabled{opacity:.4;cursor:not-allowed}.create-task-modal{max-width:640px}.create-task-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.create-task-parent-selected{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px}.create-task-parent-label{flex:1;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.create-task-parent-clear{background:none;border:none;cursor:pointer;color:var(--color-text-subtle);font-size:16px;line-height:1;padding:0 2px}.create-task-parent-clear:hover{color:var(--color-danger)}.create-task-parent-dropdown{position:absolute;left:0;right:0;top:calc(100% + 2px);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001f;z-index:50;max-height:220px;overflow-y:auto}.create-task-parent-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--color-border)}.create-task-parent-item:last-child{border-bottom:none}.create-task-parent-item:hover{background:var(--color-bg)}.create-task-parent-id{color:var(--color-text-subtle);font-size:12px;flex-shrink:0}.create-task-parent-subject{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.create-task-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--color-border)}.stt-loading{padding:32px;text-align:center;color:#9ca3af;font-size:13px}.stt-container{display:flex;flex-direction:column;min-height:300px}.stt-toolbar{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #F0F2F5;margin-bottom:12px;flex-wrap:wrap}.stt-legend{display:flex;gap:12px;align-items:center}.stt-legend-item{display:flex;align-items:center;gap:4px;font-size:11px;color:#9ca3af}.stt-legend-dot{width:8px;height:8px;border-radius:4px;flex-shrink:0}.stt-toolbar-spacer{flex:1}.stt-progress-pill{display:flex;align-items:center;gap:8px;padding:4px 10px;background:#fff;border:1px solid #E8EAED;border-radius:6px}.stt-progress-text{font-size:10px;font-weight:600;color:#10b981}.stt-progress-text.purple{color:#8b5cf6}.stt-progress-bar{display:flex;width:60px;height:4px;border-radius:2px;overflow:hidden;background:#e8eaed}.stt-bar-seg{height:100%}.stt-canvas{overflow:auto;padding:8px 0}.stt-erd{display:flex;align-items:flex-start;gap:0;min-width:fit-content;min-height:fit-content;padding-bottom:16px}.stt-level{display:flex;align-items:center;flex-shrink:0}.stt-level-parent{opacity:.8}.stt-level-children{display:flex;align-items:stretch;position:relative}.stt-children-list{display:flex;flex-direction:column;gap:8px;padding:4px 0}.stt-vline{width:2px;background:#d1d5db;align-self:stretch;margin:12px 0;flex-shrink:0}.stt-vline-sm{width:1.5px;background:#e8eaed;align-self:stretch;margin:8px 0;flex-shrink:0}.stt-connector-h{width:32px;height:2px;background:#d1d5db;flex-shrink:0;align-self:center}.stt-connector-h-sm{width:16px;height:0;border-top:2px dashed #D1D5DB;flex-shrink:0}.stt-connector-dot{width:8px;height:8px;border-radius:4px;flex-shrink:0}.stt-subtask-row{display:flex;align-items:center}.stt-subtask-group{display:flex;align-items:flex-start;gap:0}.stt-node{width:220px;background:#fff;border:2px solid #E8EAED;border-radius:8px;cursor:pointer;transition:box-shadow .15s,transform .1s;overflow:hidden;flex-shrink:0}.stt-node:hover{box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.stt-node-sm{width:200px}.stt-node-xs{width:170px}.stt-node-current{width:240px}.stt-node-parent{width:180px}.stt-node-head{display:flex;align-items:center;gap:5px;padding:0 10px;height:28px;background:#f7f8fa}.stt-node-head-dark{background:#1a1a1a}.stt-node-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.stt-node-id{font-size:10px;font-weight:600;color:#888}.stt-head-spacer{flex:1}.stt-node-status-badge{font-size:8px;font-weight:600;padding:1px 5px;border-radius:3px;white-space:nowrap;margin-left:auto}.stt-node-status-text{font-size:8px;font-weight:600;white-space:nowrap}.stt-unlink-btn{width:16px;height:16px;border:none;background:none;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#9ca3af;padding:0;flex-shrink:0;opacity:0;transition:opacity .15s,background .1s}.stt-node:hover .stt-unlink-btn{opacity:1}.stt-unlink-btn:hover{background:#fef2f2;color:#ef4444}.stt-node-body{padding:8px 10px;display:flex;flex-direction:column;gap:4px}.stt-node-subject{font-size:11px;font-weight:600;color:#1a1a1a;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.stt-node-hint{font-size:9px;color:#9ca3af;font-style:italic}.stt-node-meta-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.stt-node-assignee{display:flex;align-items:center;gap:4px;font-size:10px;color:#666}.stt-avatar-sm{width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:6px;font-weight:700;color:#fff;flex-shrink:0}.stt-node-age{display:flex;align-items:center;gap:3px;font-size:9px;color:#9ca3af}.stt-node-age.stale{color:#ef4444}.stt-node-footer{padding:5px 10px;font-size:10px;color:#888;background:#f9fafb;border-top:1px solid #E8EAED}.stt-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:200px;height:36px;border:2px dashed #E8EAED;border-radius:8px;background:#fff;color:#4a9fd8;font-size:12px;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.stt-add-btn:hover{border-color:#4a9fd8;background:#ebf5fb}.stt-add-btn--create{border-color:#d1fae5;color:#10b981}.stt-add-btn--create:hover{border-color:#10b981;background:#ecfdf5}.stt-nested{display:flex;align-items:flex-start;margin-left:8px}.stt-nested-label{writing-mode:vertical-lr;font-size:7px;font-weight:600;color:#8b5cf6;background:#ede9fe;padding:4px 2px;border-radius:3px;margin-right:4px;align-self:center;letter-spacing:.04em}.stt-nested-children{display:flex;align-items:stretch}.stt-nested-children .stt-children-list{gap:6px}.stt-search-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000014;z-index:10;display:flex;align-items:center;justify-content:center}.stt-search-popup{width:400px;max-height:340px;background:#fff;border:1px solid #E8EAED;border-radius:10px;box-shadow:0 8px 24px #0000001f;overflow:hidden;display:flex;flex-direction:column}.stt-search-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid #E8EAED;color:#9ca3af}.stt-search-input{flex:1;border:none;outline:none;font-size:13px;color:#111827;background:transparent}.stt-search-close{border:none;background:none;cursor:pointer;color:#9ca3af;padding:2px;border-radius:4px}.stt-search-close:hover{background:#f3f4f6;color:#374151}.stt-search-results{overflow-y:auto;max-height:280px}.stt-search-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;border:none;background:none;cursor:pointer;text-align:left;transition:background .1s;font-size:13px}.stt-search-item:hover{background:#f9fafb}.stt-search-item-id{font-size:11px;font-weight:600;color:#888;flex-shrink:0}.stt-search-item-subject{flex:1;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stt-search-item-status{font-size:10px;font-weight:600;flex-shrink:0}.stt-search-empty{padding:20px;text-align:center;color:#9ca3af;font-size:13px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#091e428a;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;overflow-y:auto}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay);min-width:500px;height:85vh;max-height:85vh;overflow-y:auto;position:relative}.modal-resize-handle{position:absolute;top:0;bottom:0;width:6px;cursor:col-resize;z-index:10}.modal-resize-handle:hover,.modal-resize-handle:active{background:#4a9fd826}.modal-resize-left{left:0;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.modal-resize-right{right:0;border-radius:0 var(--radius-lg) var(--radius-lg) 0}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-content.file-drag-over{outline:3px dashed var(--color-primary);outline-offset:-3px}.modal-id{font-size:13px;display:flex;align-items:center;gap:6px;color:var(--color-text-subtle)}.modal-title{font-size:20px;font-weight:600;margin-top:4px}.modal-title.editable{cursor:pointer;border-radius:var(--radius);padding:2px 4px;margin:2px -4px;transition:background .15s}.modal-title.editable:hover{background:var(--color-bg)}.modal-title-input{font-size:20px;font-weight:600;padding:4px 8px;width:100%;margin-top:4px}.modal-close{background:none;border:none;font-size:28px;color:var(--color-text-subtle);cursor:pointer;line-height:1;padding:0 4px}.modal-close:hover{color:var(--color-text)}.modal-delete-btn{display:flex;align-items:center;justify-content:center;background:none;border:1px solid transparent;border-radius:6px;padding:5px 7px;color:var(--color-text-subtle);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.modal-delete-btn:hover{background:#fef2f2;color:#ef4444;border-color:#fecaca}.modal-body{padding:24px}.modal-section{margin-bottom:24px}.modal-section h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-subtle);margin-bottom:0}.modal-section-header{display:flex;align-items:center;gap:6px;margin-bottom:12px}.modal-section-edit-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text-subtle);padding:2px 4px;border-radius:4px;opacity:0;transition:opacity .15s,background .15s}.modal-section:hover .modal-section-edit-btn{opacity:1}.modal-section-edit-btn:hover{background:var(--color-column-bg);color:var(--color-accent)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;color:var(--color-text-subtle);font-weight:500}.detail-value{font-size:14px;color:var(--color-text)}.detail-work-time{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--color-primary);background:var(--color-primary-light);padding:2px 8px;border-radius:var(--radius);font-size:13px}.work-btn-modal{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-subtle);cursor:pointer;transition:all .15s;padding:0;flex-shrink:0}.work-btn-modal:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.work-btn-modal--active{border-color:#00875a;color:#00875a;background:#00875a14}.work-btn-modal--active:hover{border-color:#ffab00;color:#ffab00;background:#ffab0014}.work-btn-modal:disabled{opacity:.5;cursor:not-allowed}.description-text{font-size:14px;color:var(--color-text);white-space:pre-wrap;line-height:1.6;background:var(--color-bg);padding:12px;border-radius:var(--radius);max-height:200px;overflow-y:auto}.modal-progress-bar{display:flex;align-items:center;gap:10px;padding:6px 24px}.modal-progress-slider{flex:1;height:6px;cursor:pointer;accent-color:var(--color-primary)}.modal-progress-label{font-size:12px;font-weight:600;color:var(--color-text-subtle);min-width:32px;text-align:right}.modal-tabs{display:flex;gap:2px;padding:0 24px;border-bottom:1px solid var(--color-border)}.modal-tab{padding:10px 16px;border:none;background:none;font-size:14px;font-weight:500;color:var(--color-text-subtle);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.modal-tab:hover{color:var(--color-text)}.styled-select-wrap{position:relative}.styled-select{width:100%;padding:8px 32px 8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:14px;font-family:inherit;color:var(--color-text);cursor:pointer;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236B778C' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color .15s,box-shadow .15s}.styled-select:hover{border-color:var(--color-text-subtle)}.styled-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.estimate-locked-hint{font-size:11px;font-weight:400;color:var(--color-text-subtle);text-transform:none;letter-spacing:0}.estimate-row{display:flex;gap:16px;flex-wrap:wrap}.estimate-field{flex:1;min-width:180px}.comments-list{margin-bottom:16px}.comment-item{padding:10px 0;border-bottom:1px solid var(--color-border)}.comment-item--private{background:#faf5ff;border-radius:6px;padding:8px 10px;border-bottom:1px solid #EDE9FE}.comment-private-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:8px;background:#ede9fe;color:#8b5cf6;font-size:10px;font-weight:600;margin-left:6px}.comment-privacy-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:8px;border:1px solid var(--color-border);background:transparent;color:#9ca3af;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.comment-privacy-btn:hover{border-color:#8b5cf6;color:#8b5cf6}.comment-privacy-btn.active{background:#ede9fe;border-color:#8b5cf6;color:#8b5cf6}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:13px}.comment-date{font-size:12px;color:var(--color-text-subtle)}.comment-text{font-size:14px;line-height:1.5;white-space:pre-wrap}.comments-empty{color:var(--color-text-subtle);text-align:center;padding:24px}.mention{color:var(--color-primary);font-weight:600}.comment-form{display:flex;flex-direction:column;gap:8px}.comment-input{resize:vertical;min-height:60px}.status-timeline{margin-bottom:24px;padding:16px;background:var(--color-bg);border-radius:var(--radius-lg)}.tl-card{background:#fff;border:1px solid #E8EAED;border-radius:10px;padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.tl-header{display:flex;align-items:center;gap:8px}.tl-title{font-size:13px;font-weight:700;color:#1a1a1a}.tl-spacer{flex:1}.tl-dates{font-size:11px;color:#9ca3af}.tl-bar{display:flex;height:28px;border-radius:6px;overflow:hidden;gap:0}.tl-seg{height:100%;display:flex;align-items:center;justify-content:center;min-width:20px;cursor:default;transition:opacity .15s;overflow:hidden}.tl-seg:hover{opacity:.85}.tl-seg-label{font-size:9px;font-weight:600;color:#fff;white-space:nowrap;padding:0 4px}.tl-legend{display:flex;gap:16px;flex-wrap:wrap}.tl-legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:#666}.tl-legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.status-time-table{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.status-time-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#f9fafb;border-radius:6px;font-size:12px}.status-time-label{flex:1;color:#374151;font-weight:500}.status-time-biz{color:#111827;font-weight:600;font-size:13px}.status-time-biz small{font-weight:400;color:#6b7280;font-size:10px}.status-time-total{color:#9ca3af;font-size:11px}.hst-events-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:#1a1a1a;margin-bottom:8px}.hst-list{background:#fff;border:1px solid #E8EAED;border-radius:10px;overflow:hidden}.hst-item{display:flex;gap:12px;padding:12px 16px;align-items:flex-start;border-bottom:1px solid #F3F4F6}.hst-item:last-child{border-bottom:none}.hst-icon{width:28px;height:28px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hst-icon-inner{display:flex;align-items:center;justify-content:center}.hst-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.hst-top{display:flex;align-items:center;gap:8px}.hst-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;white-space:nowrap}.hst-user{font-size:12px;color:#1a1a1a}.hst-spacer{flex:1}.hst-date{font-size:11px;color:#9ca3af;white-space:nowrap}.hst-status-change{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500}.hst-estimates{display:flex;gap:12px;font-size:11px;color:#888;flex-wrap:wrap}.hst-estimates b{color:#1a1a1a}.hst-detail-text{font-size:11px;color:#666}.copy-link-btn{background:none;border:none;color:var(--color-text-subtle);cursor:pointer;padding:2px;border-radius:var(--radius);transition:color .15s}.copy-link-btn:hover{color:var(--color-primary)}.global-toast{position:fixed;bottom:24px;right:24px;z-index:400;padding:10px 20px;border-radius:var(--radius-lg);font-size:14px;font-weight:500;box-shadow:var(--shadow-overlay);animation:global-toast-in .25s ease-out}.global-toast-success{background:#e3fcef;border-left:4px solid var(--color-success);color:var(--color-success)}@keyframes global-toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.att-header{display:flex;align-items:center;gap:8px}.att-header h3{flex:1}.att-upload-btn{padding:4px 12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#4a9fd8;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.att-upload-btn:hover{background:#ebf5fb}.att-upload-btn:disabled{opacity:.5;cursor:not-allowed}.att-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.att-item{display:flex;align-items:flex-start;gap:8px;position:relative}.att-image-preview{display:block;max-width:280px;border-radius:8px;overflow:hidden;border:1px solid #E8EAED}.att-image-preview img{display:block;max-width:100%;max-height:200px;object-fit:cover}.att-image-preview:hover{border-color:#4a9fd8}.att-file-link{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f7f8fa;border:1px solid #E8EAED;border-radius:8px;text-decoration:none;color:#111827;transition:background .15s;min-width:200px}.att-file-link:hover{background:#ebf5fb;border-color:#b8d9ef}.att-file-ext{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;background:#ebf5fb;color:#4a9fd8;font-size:10px;font-weight:700;flex-shrink:0}.att-file-info{display:flex;flex-direction:column;gap:1px;min-width:0}.att-file-name{font-size:13px;font-weight:500;color:#1a1a1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-file-size{font-size:11px;color:#9ca3af}.att-delete-btn{width:24px;height:24px;border:none;border-radius:6px;background:none;color:#d1d5db;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .1s;flex-shrink:0;margin-top:4px}.att-item:hover .att-delete-btn{opacity:1}.att-delete-btn:hover{background:#fef2f2;color:#ef4444}.modal-section-subtree{min-height:300px;overflow:visible}.subtask-parent-block{padding:12px;background:var(--color-bg);border-radius:var(--radius);margin-bottom:12px}.subtask-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:14px;font-weight:600}.subtask-action-row{margin-bottom:12px}.subtask-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--color-border);font-size:14px}.subtask-item:last-child{border-bottom:none}.subtask-id{font-size:12px;color:var(--color-text-subtle);flex-shrink:0}.subtask-subject{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subtask-assignee{font-size:12px;color:var(--color-primary);flex-shrink:0}.task-search-popup{margin-top:12px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-overlay);overflow:hidden}.task-search-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--color-bg);font-size:13px;font-weight:600;border-bottom:1px solid var(--color-border)}.task-search-popup .form-input{border:none;border-bottom:1px solid var(--color-border);border-radius:0;padding:10px 12px}.task-search-list{max-height:250px;overflow-y:auto}.task-search-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:14px;transition:background .1s}.task-search-item:hover,.task-search-item.active{background:var(--color-primary-light)}.task-search-empty{padding:16px;text-align:center;color:var(--color-text-subtle);font-size:13px}.billing-section{background:#fffbf0;border:1px solid #FDE68A;border-radius:var(--radius);padding:14px 16px}.billing-header{display:flex;align-items:center;gap:8px;margin-bottom:0}.billing-body{margin-top:12px;display:flex;flex-direction:column;gap:10px}.billing-row{display:flex;align-items:center;gap:12px}.billing-row .detail-label{min-width:140px;flex-shrink:0}.billing-hours-input{width:90px;padding:5px 8px;font-size:13px}.billing-status-pills{display:flex;gap:6px;flex-wrap:wrap}.billing-pill{padding:4px 12px;border-radius:12px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-subtle);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.billing-pill:not(:disabled):hover{border-color:#d97706;color:#d97706}.billing-pill:disabled{cursor:default;opacity:.8}.billing-paid-date{font-size:12px;color:#27ae60;font-weight:500;padding-left:2px}.billing-toggle{position:relative;display:inline-flex;cursor:pointer;margin-left:auto}.billing-toggle input{opacity:0;width:0;height:0;position:absolute}.billing-toggle-slider{width:34px;height:18px;background:#d1d5db;border-radius:9px;transition:background .2s;position:relative}.billing-toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s}.billing-toggle input:checked+.billing-toggle-slider{background:#d97706}.billing-toggle input:checked+.billing-toggle-slider:after{transform:translate(16px)}.task-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:10px 12px;cursor:default;transition:box-shadow .15s,transform .1s;-webkit-user-select:none;user-select:none}.task-card:hover{box-shadow:var(--shadow-overlay);transform:translateY(-1px)}.task-card:active{opacity:.8}.task-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.task-card-id{font-size:12px;color:var(--color-text-subtle)}.task-card-days{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;color:#9ca3af;background:#f3f4f6;padding:2px 6px;border-radius:4px}.task-card-days.stale{color:#ef4444;background:#fef2f2}.task-card-meta{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:4px}.task-type-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:8px}.task-card-assignee{font-size:12px;color:var(--color-primary);margin-bottom:4px}.task-card-subject{font-size:14px;font-weight:500;margin-bottom:8px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-card-indicators{display:flex;gap:6px;align-items:center;margin-bottom:4px}.task-indicator{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:500;color:#9ca3af;padding:1px 6px;border-radius:4px;background:#f3f4f6}.task-indicator.active{color:#4a9fd8;background:#ebf5fb;animation:indicator-pulse 2s ease-in-out infinite}.task-indicator.mention{color:#f59e0b;background:#fef3c7;font-weight:700;animation:indicator-pulse 2s ease-in-out infinite}@keyframes indicator-pulse{0%,to{opacity:1}50%{opacity:.6}}.task-card-estimates{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}.estimate-badge{font-size:11px;font-weight:600;padding:2px 6px;border-radius:3px}.estimate-badge.filled{background:var(--color-primary-light);color:var(--color-primary)}.estimate-badge.empty{background:var(--color-estimate-empty-bg, #DFE1E6);color:var(--color-estimate-empty-text, var(--color-text-subtle))}.task-card-progress{display:flex;align-items:center;gap:6px;margin-top:6px}.task-progress-track{flex:1;height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.task-progress-fill{height:100%;border-radius:2px;transition:width .3s}.task-progress-label{font-size:10px;font-weight:600;color:var(--color-text-subtle);min-width:28px;text-align:right}.task-card-subtasks{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:12px;color:var(--color-text-subtle)}.subtask-icon{font-size:10px}.subtask-dots{display:flex;gap:3px}.subtask-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border)}.subtask-dot.subtask-queue{background:#0065ff}.subtask-dot.subtask-in_progress{background:#6554c0}.subtask-dot.subtask-done{background:#00875a}.subtask-dot.subtask-unestimated{background:#ff991f}.task-card-parent{font-size:11px;color:var(--color-primary);margin-top:4px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-card-parent:hover{text-decoration:underline}.task-score{font-size:11px;font-weight:700;padding:2px 6px;border-radius:3px;background:#e3fcef;color:var(--color-success);margin-left:auto}.task-card-flags{display:flex;align-items:center;gap:4px}.task-flag{font-size:13px;cursor:pointer;opacity:.3;transition:opacity .15s}.task-flag:hover{opacity:.8}.task-flag.active,.task-flag-pin{opacity:1}.task-flag-fire.active{animation:fire-pulse 1.5s ease-in-out infinite}@keyframes fire-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.task-card--important{border-left:3px solid #ff6b35}.task-card--pinned{background:var(--color-pinned-bg, rgba(0, 101, 255, .04));border:1px solid var(--color-primary-light)}.task-card-menu{position:absolute;top:8px;right:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-overlay);z-index:50;min-width:150px;padding:4px 0}.task-card-menu-item{padding:8px 12px;font-size:13px;cursor:pointer;transition:background .1s}.task-card-menu-item:hover{background:var(--color-primary-light)}.task-flag-star{font-size:14px;color:#c1c7d0;cursor:pointer;opacity:.5;transition:opacity .15s,color .15s,transform .15s}.task-flag-star:hover{opacity:1;color:#ffab00;transform:scale(1.2)}.task-flag-star.active{opacity:1;color:#ffab00;text-shadow:0 0 4px rgba(255,171,0,.4)}.task-card--selected{outline:2px solid var(--color-primary);background:var(--color-primary-light)}.task-card-checkbox{position:absolute;top:6px;left:6px;z-index:10}.task-card-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.task-card{position:relative}.task-card--paused{border-left:3px solid #FFAB00;animation:paused-pulse 2.5s ease-in-out infinite}@keyframes paused-pulse{0%,to{background:var(--color-surface)}50%{background:#ffab0012}}.task-card--working{border-left:3px solid #00875A}.task-card-work{display:flex;align-items:center;gap:6px;margin:4px 0}.work-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-subtle);cursor:pointer;transition:all .15s;padding:0;flex-shrink:0}.work-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.work-btn--active{border-color:#00875a;color:#00875a;background:#00875a14}.work-btn--active:hover{border-color:#ffab00;color:#ffab00;background:#ffab0014}.work-btn:disabled{opacity:.5;cursor:not-allowed}.work-timer{font-size:11px;font-family:monospace;color:var(--color-text-subtle);line-height:1}.billing-badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;margin:4px 0 0}.task-card-deadline{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 5px;border-radius:4px;color:#9ca3af;background:#f3f4f6}.task-card-deadline.deadline--warning{color:#d97706;background:#fef3c7}.task-card-deadline.deadline--urgent{color:#c2410c;background:#fee2e2;animation:deadline-pulse 1.5s ease-in-out infinite}.task-card-deadline.deadline--overdue{color:#991b1b;background:#fee2e2;animation:deadline-pulse 1.5s ease-in-out infinite}.task-card.deadline--warning{border-left:3px solid #D97706}.task-card.deadline--urgent{border-left:3px solid #EF4444}.task-card.deadline--overdue{border-left:3px solid #991B1B}@keyframes deadline-pulse{0%,to{opacity:1}50%{opacity:.65}}.kanban-column{min-width:280px;max-width:320px;flex:0 0 300px;background:#fff;border-radius:12px;border:1px solid #E8EAED;display:flex;flex-direction:column;transition:background .15s,border-color .15s;overflow:hidden}.kanban-column.drag-over{background:#ebf5fb;border-color:#4a9fd8}.kanban-column.column-active{border-color:#4a9fd8}.column-header{display:flex;align-items:center;gap:8px;padding:0 14px;height:46px;flex-shrink:0}.column-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.column-title{font-size:13px;font-weight:600;color:#111827;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.column-count{font-size:12px;font-weight:600;padding:1px 7px;border-radius:10px;height:20px;display:inline-flex;align-items:center}.column-count.over-limit{background:#fef2f2!important;color:#ef4444!important}.column-divider{height:1px;flex-shrink:0}.column-add-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:6px;background:transparent;color:#888;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}.column-add-btn:hover{background:var(--color-bg);color:var(--color-text)}.column-cards{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.column-card-wrapper.drop-indicator{border-top:2px solid var(--color-primary);padding-top:2px}.column-card-wrapper.sortable{cursor:default}.column-empty{text-align:center;color:#9ca3af;font-size:13px;padding:24px 8px}.column-show-more{width:100%;padding:8px;border:1px dashed #E8EAED;border-radius:8px;background:transparent;color:#4a9fd8;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.column-show-more:hover{background:#ebf5fb;border-color:#4a9fd8}.bulk-action-bar{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top:2px solid var(--color-primary);box-shadow:0 -4px 20px #00000026;padding:12px 24px;display:flex;align-items:center;gap:16px;z-index:200;animation:bulk-bar-in .2s ease-out}@keyframes bulk-bar-in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.bulk-action-count{font-size:14px;font-weight:600;color:var(--color-primary);min-width:100px}.bulk-action-group{display:flex;align-items:center;gap:8px}.bulk-action-group label{font-size:13px;color:var(--color-text-subtle);white-space:nowrap}.bulk-action-group select{padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:13px;min-width:140px}.bulk-action-buttons{display:flex;gap:8px;margin-left:auto}.bulk-action-buttons .btn{padding:6px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .15s,color .15s}.bulk-btn-apply{background:var(--color-primary);color:#fff}.bulk-btn-apply:hover{opacity:.9}.bulk-btn-apply:disabled{opacity:.5;cursor:not-allowed}.bulk-btn-delete{background:var(--color-danger);color:#fff}.bulk-btn-delete:hover{opacity:.9}.bulk-btn-cancel{background:transparent;color:var(--color-text-subtle);border-color:var(--color-border)}.bulk-btn-cancel:hover{background:var(--color-border)}.kanban-board{display:flex;gap:16px;flex:1;height:100%;overflow-x:auto;padding:16px;align-items:flex-start;min-width:min-content}.toast-container{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;flex-direction:column;gap:8px;max-width:400px}.toast{padding:14px 18px;border-radius:10px;box-shadow:0 4px 16px #0000001f;cursor:pointer;animation:toast-in .3s ease-out}.toast-error{background:#fef2f2;border-left:4px solid #EF4444}.toast-success{background:#ecfdf5;border-left:4px solid #10B981}.toast-title{font-size:14px;font-weight:600;color:#111827;margin-bottom:4px}.toast-detail{font-size:13px;color:#6b7280;line-height:1.4}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skel-bar,.skel-card{background:linear-gradient(90deg,#e8eaed 25%,#f5f6f8,#e8eaed 75%);background-size:1200px 100%;animation:shimmer 1.6s ease-in-out infinite}.skel-title{flex:1;height:13px;border-radius:4px}.skel-badge{width:30px;height:20px;border-radius:8px}.skel-card{border-radius:10px;flex-shrink:0}.skel-card:nth-child(2){animation-delay:.15s}.skel-card:nth-child(3){animation-delay:.3s}.skel-card:nth-child(4){animation-delay:.45s}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.filter-bar{display:flex;align-items:center;gap:6px;width:100%;height:100%}.filter-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #E8EAED;border-radius:7px;background:#f7f8fa;color:#666;cursor:pointer;flex-shrink:0;transition:border-color .15s}.filter-icon-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-my-tasks-btn{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 10px;border:1px solid #E8EAED;border-radius:7px;background:#f7f8fa;color:#444;font-size:12px;font-weight:400;font-family:inherit;cursor:pointer;transition:border-color .15s;white-space:nowrap}.filter-my-tasks-btn:hover{border-color:var(--color-primary)}.filter-my-tasks-btn.active{background:#ebf5fb;border-color:#b8d9ef;color:#4a9fd8;font-weight:600}.filter-dropdown{position:relative}.filter-dropdown-toggle{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 10px;border:1px solid #E8EAED;border-radius:7px;background:#f7f8fa;color:#444;font-size:12px;font-weight:400;font-family:inherit;cursor:pointer;white-space:nowrap;transition:border-color .15s}.filter-dropdown-toggle svg{color:#888}.filter-dropdown-toggle:hover{border-color:var(--color-primary)}.filter-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:#fff;border:1px solid #E8EAED;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:150;max-height:280px;overflow-y:auto}.filter-dropdown-item{display:block;width:100%;padding:8px 12px;text-align:left;border:none;background:transparent;font-size:13px;font-family:inherit;color:#111827;cursor:pointer;transition:background .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.filter-dropdown-item:hover{background:#f0f2f5}.filter-dropdown-empty{padding:10px 12px;font-size:13px;color:#9ca3af}.filter-chip{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 8px 0 10px;border-radius:7px;font-size:12px;font-weight:600;white-space:nowrap}.filter-chip--active{background:#ebf5fb;border:1px solid #B8D9EF;color:#4a9fd8}.filter-chip-label{max-width:120px;overflow:hidden;text-overflow:ellipsis}.filter-chip-clear{display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#4a9fd8;cursor:pointer;padding:2px;border-radius:3px}.filter-chip-clear:hover{background:#4a9fd826}.filter-clear-btn{padding:0 4px;height:30px;border:none;background:transparent;color:#4a9fd8;font-size:12px;font-family:inherit;cursor:pointer;white-space:nowrap;transition:opacity .15s}.filter-clear-btn:hover{opacity:.7}.filter-spacer{flex:1}.filter-create-btn{height:32px;padding:0 14px;font-size:13px;font-weight:600;border-radius:8px;background:#4a9fd8;color:#fff;border:none;flex-shrink:0;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:background .15s}.filter-create-btn:hover{background:#3a8fc8}.notif-wrap{position:relative}.notif-bell{background:none;border:none;color:inherit;cursor:pointer;position:relative;padding:4px;opacity:.7;transition:opacity .15s}.notif-bell:hover{opacity:1}.notif-badge{position:absolute;top:-4px;right:-6px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.notif-dropdown{position:absolute;top:100%;right:0;width:340px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay);z-index:200;overflow:hidden}.notif-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--color-border);font-weight:600;font-size:14px}.notif-list{max-height:400px;overflow-y:auto}.notif-item{padding:10px 14px;border-bottom:1px solid var(--color-border);cursor:pointer;font-size:13px}.notif-item:hover{background:var(--color-bg)}.notif-item.unread{border-left:3px solid var(--color-primary)}.notif-title{font-weight:500;margin-bottom:2px}.notif-body{color:var(--color-text-subtle);font-size:12px}.notif-time{font-size:11px;color:var(--color-text-subtle);margin-top:4px}.notif-empty{padding:24px;text-align:center;color:var(--color-text-subtle)}@media (max-width: 600px){.notif-dropdown{width:280px;right:-40px}}.board-page{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--color-bg)}.page-topbar{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 24px;height:56px;flex-shrink:0;gap:16px}.page-topbar-left{display:flex;align-items:center;gap:8px}.page-breadcrumb-project{font-size:14px;color:#888;font-weight:400}.page-breadcrumb-sep{color:#888;flex-shrink:0}.page-breadcrumb-current{font-size:14px;font-weight:600;color:var(--color-text)}.page-topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto}.page-version-badge{display:inline-flex;align-items:center;gap:4px;height:24px;padding:0 8px;border-radius:6px;border:1px solid var(--color-border);background:#f7f8fa;color:#666;font-size:11px;font-weight:600;font-family:monospace;cursor:pointer;transition:background .15s;white-space:nowrap}.page-version-badge:hover{background:var(--color-border);color:var(--color-text)}.page-search-field{display:inline-flex;align-items:center;gap:8px;width:200px;height:34px;padding:0 12px;border-radius:8px;border:1px solid var(--color-border);background:#f7f8fa;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left}.page-search-field:hover{border-color:var(--color-primary)}.page-search-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #4a9fd826}.page-search-icon{color:#888;flex-shrink:0}.page-search-placeholder{font-size:13px;color:#888;font-family:inherit;white-space:nowrap}.page-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--color-border);background:transparent;color:#888;cursor:pointer;transition:background .15s,color .15s}.page-icon-btn:hover{background:var(--color-border);color:var(--color-text)}.page-toolbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 16px;height:52px;flex-shrink:0;display:flex;align-items:center}.board-area{flex:1;overflow:hidden;overflow-x:auto;display:flex;flex-direction:column}.loading-bar{text-align:center;padding:8px;color:var(--color-text-subtle);font-size:13px;background:var(--color-bg);flex-shrink:0}.estimate-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5;position:relative}.estimate-page .page-topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0;gap:16px}.estimate-page .page-topbar-left{display:flex;align-items:center;gap:8px}.estimate-page .page-breadcrumb-project{font-size:14px;color:#888;font-weight:400}.estimate-page .page-breadcrumb-sep{color:#888}.estimate-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.estimate-content{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;gap:16px;min-height:0}.estimate-stats-row{display:flex;gap:12px}.estimate-stat-card{flex:1;background:#fff;border:1px solid #E8EAED;border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:4px}.estimate-stat-card.formula{background:#ebf5fb;border-color:#b8d9ef;gap:6px}.estimate-stat-desc{font-size:11px;color:#888}.estimate-stat-desc.blue-label,.estimate-stat-card.formula .estimate-stat-desc{color:#4a9fd8;font-weight:600}.estimate-stat-row{display:flex;align-items:center;gap:8px}.estimate-stat-num{font-size:28px;font-weight:700;color:#1a1a1a;line-height:1}.estimate-stat-num.ok{color:#27ae60}.estimate-stat-num.blue{color:#4a9fd8}.estimate-stat-unit{font-size:13px;color:#888}.estimate-formula-row{display:flex;align-items:center;gap:4px}.formula-part{font-size:11px;font-weight:600;color:#1a1a1a}.formula-div{font-size:16px;font-weight:700;color:#4a9fd8}.formula-scale{font-size:10px;color:#666}.estimate-toolbar{display:flex;align-items:center;gap:16px}.estimate-search{height:34px;width:240px;padding:0 12px;font-size:13px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none}.estimate-search:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd826}.estimate-filter-select{height:34px;padding:0 28px 0 12px;font-size:13px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.estimate-filter-select:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd826}.estimate-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none}.estimate-toggle input{cursor:pointer;accent-color:#4A9FD8}.estimate-table-wrap{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column}.estimate-table{background:#fff;border:1px solid #E8EAED;border-radius:12px;overflow:hidden;width:100%;min-width:960px}.est-col{display:flex;align-items:center;flex-shrink:0;min-width:0}.est-col-task{width:280px;padding:0 16px;gap:8px}.est-col-type{width:100px;padding:0 12px}.est-col-sub{width:130px;padding:0 12px}.est-col-bv,.est-col-urg{width:110px;padding:0 12px;gap:4px}.est-col-eff{width:130px;padding:0 12px;gap:4px}.est-col-wsjf{width:90px;padding:0 12px}.est-col-assign{flex:1;padding:0 12px;gap:8px;min-width:120px}.est-header{display:flex;width:100%;height:42px;background:#f7f8fa;border-bottom:1px solid #E8EAED;position:sticky;top:0;z-index:2}.est-header .est-col{font-size:12px;font-weight:600;color:#888;white-space:nowrap}.est-header .est-col svg{color:#888;flex-shrink:0}.est-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .1s}.est-sortable:hover{color:#374151!important}.est-sort-active{color:#4a9fd8!important}.est-body{display:flex;flex-direction:column}.est-row{display:flex;width:100%;height:52px;flex-shrink:0;border-bottom:1px solid #F0F2F5;cursor:pointer;transition:background .1s}.est-row:last-child{border-bottom:none}.est-row:hover{background:#f9fafb}.est-row.partial{background:#fffbf0;border-bottom-color:#f5e9cc}.est-row.partial:hover{background:#fff7e0}.est-row.selected{background:#ebf5fb!important}.est-task-id{font-size:11px;font-weight:600;color:#888;background:#f7f8fa;padding:2px 7px;border-radius:4px;flex-shrink:0;height:20px;display:inline-flex;align-items:center}.est-task-subject{font-size:13px;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.est-cell-text{font-size:13px;color:#666}.est-cell-muted{font-size:13px;color:#b8bcc4}.est-type-badge{display:inline-flex;align-items:center;font-size:12px;padding:2px 8px;height:22px;border-radius:11px;background:#ebf5fb;color:#4a9fd8}.est-val{font-size:15px;font-weight:700;color:#1a1a1a}.est-not-set{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#b8bcc4}.est-not-set svg{flex-shrink:0}.est-not-set.warn{color:#f5a623}.est-wsjf{font-size:15px;font-weight:700;color:#4a9fd8}.est-wsjf-empty{font-size:15px;font-weight:700;color:#b8bcc4}.est-avatar{width:26px;height:26px;border-radius:50%;background:#e8a838;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.est-row-empty{text-align:center;padding:32px;color:#9ca3af;font-size:14px}.est-row-loading{text-align:center;padding:16px;color:#9ca3af;font-size:12px}.estimate-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000026;z-index:200}.estimate-drawer{position:fixed;top:0;right:0;bottom:0;width:440px;background:#fff;z-index:201;display:flex;flex-direction:column;box-shadow:-4px 0 24px #0000001a}.drawer-header{display:flex;align-items:center;justify-content:space-between;gap:8px;height:56px;padding:0 20px;border-bottom:1px solid #E8EAED;flex-shrink:0}.drawer-header-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.drawer-task-id-badge{font-size:11px;font-weight:600;color:#888;background:#f7f8fa;padding:2px 6px;border-radius:4px;flex-shrink:0}.drawer-task-subject{font-size:14px;font-weight:700;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-close{flex-shrink:0;width:28px;height:28px;border:none;background:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#888;transition:background .1s}.drawer-close:hover{background:#f3f4f6}.drawer-body{flex:1;overflow-y:auto}.drawer-section{border-bottom:1px solid #F0F2F5}.drawer-meta-row{display:flex;align-items:center;gap:16px;padding:14px 20px;border-bottom:1px solid #F0F2F5}.drawer-meta-badge{display:inline-flex;align-items:center;font-size:11px;padding:3px 8px;border-radius:11px}.drawer-meta-badge.type{background:#eafaf1;color:#27ae60}.drawer-meta-badge.subsystem{background:#f7f8fa;color:#666;border:1px solid #E8EAED}.drawer-meta-assignee{display:flex;align-items:center;gap:6px;font-size:11px;color:#666}.drawer-meta-avatar{width:20px;height:20px;border-radius:50%;background:#e74c3c;color:#fff;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center}.drawer-desc-label{font-size:11px;font-weight:600;color:#888;margin-bottom:4px;padding:14px 20px 0}.drawer-description{font-size:12px;line-height:1.5;color:#444;padding:0 20px 14px;white-space:pre-wrap;max-height:160px;overflow-y:auto}.drawer-meta-edit{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px 20px}.drawer-assignee-section{padding:14px 20px}.drawer-field{display:flex;flex-direction:column;gap:6px}.drawer-field-label{font-size:11px;font-weight:600;color:#888}.drawer-select{height:32px;padding:0 28px 0 10px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#1a1a1a;outline:none;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.drawer-select:focus{border-color:#4a9fd8}.drawer-wsjf-hint{background:#fafafa;padding:12px 20px;border-bottom:1px solid #F0F2F5;display:flex;flex-direction:column;gap:8px}.drawer-hint-title{font-size:11px;font-weight:600;color:#888}.drawer-hint-fib{display:flex;gap:4px}.drawer-hint-btn{width:28px;height:28px;border-radius:6px;background:#f7f8fa;border:1px solid #E8EAED;display:flex;align-items:center;justify-content:center;font-size:11px;color:#888}.drawer-picker-section{padding:16px 20px;border-bottom:1px solid #F0F2F5;display:flex;flex-direction:column;gap:12px}.drawer-picker-top{display:flex;align-items:center;gap:8px}.drawer-picker-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.drawer-picker-icon.bv{background:#f7f8fa;color:#888}.drawer-picker-icon.urgency{background:#fff8e0;color:#f5a623}.drawer-picker-icon.effort{background:#f0f2f5;color:#666}.drawer-picker-label{display:flex;flex-direction:column;gap:2px}.drawer-picker-title{font-size:13px;font-weight:600;color:#1a1a1a}.drawer-picker-desc{font-size:11px;color:#888}.drawer-warn-row{display:flex;align-items:flex-start;gap:6px;padding:8px 10px;background:#fffbf0;border-radius:8px;font-size:11px;color:#d4820a}.drawer-warn-row svg{flex-shrink:0;color:#f5a623;margin-top:1px}.estimate-drawer .fibonacci-selector{display:flex;gap:6px;flex-wrap:wrap}.estimate-drawer .fib-btn{width:40px;height:40px;border-radius:8px;border:1px solid #E8EAED;background:#f7f8fa;font-size:13px;font-weight:400;color:#888;cursor:pointer;transition:background .1s,border-color .1s,color .1s;display:flex;align-items:center;justify-content:center;padding:0}.estimate-drawer .fib-btn:hover{background:#ebf5fb;border-color:#4a9fd8;color:#4a9fd8}.estimate-drawer .fib-btn.active{background:#1a1a1a;border-color:#1a1a1a;color:#fff;font-weight:700}.drawer-wsjf-result{display:flex;align-items:center;justify-content:space-between;background:#ebf5fb;border-bottom:1px solid #B8D9EF;padding:14px 20px}.drawer-wsjf-left{display:flex;flex-direction:column;gap:4px}.drawer-wsjf-title{font-size:12px;font-weight:600;color:#4a9fd8}.drawer-wsjf-formula{display:flex;align-items:center;gap:4px;font-size:13px;color:#666}.drawer-wsjf-formula strong{color:#1a1a1a;font-weight:700}.drawer-wsjf-big{font-size:32px;font-weight:700;color:#4a9fd8;line-height:1}.drawer-message{margin:12px 20px;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500}.drawer-message.success{background:#ecfdf5;color:#10b981}.drawer-message.error{background:#fef2f2;color:#ef4444}.drawer-footer{padding:0 20px;height:64px;border-top:1px solid #E8EAED;display:flex;align-items:center;gap:10px;flex-shrink:0}.drawer-btn-cancel{flex:1;height:38px;border:1px solid #E8EAED;border-radius:8px;background:#f7f8fa;color:#666;font-size:13px;cursor:pointer;transition:background .1s}.drawer-btn-cancel:hover{background:#f0f2f5}.drawer-btn-save{flex:1;height:38px;border:none;border-radius:8px;background:#1a1a1a;color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .1s}.drawer-btn-save:hover{background:#333}.drawer-btn-save:disabled{opacity:.6;cursor:not-allowed}.import-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5}.import-page .page-topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0;gap:16px}.import-page .page-topbar-left{display:flex;align-items:center;gap:8px}.import-page .page-breadcrumb-project{font-size:14px;color:#888;font-weight:400}.import-page .page-breadcrumb-sep{color:#888}.import-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.import-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px}.import-inner{width:100%;max-width:560px}.import-intro{margin-bottom:24px}.import-title{font-size:20px;font-weight:600;color:#111827;margin-bottom:6px}.import-subtitle{font-size:14px;color:#6b7280;line-height:1.5}.import-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;background:#fff;border:2px dashed #E8EAED;border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s;text-align:center;-webkit-user-select:none;user-select:none}.import-dropzone:hover,.import-dropzone.active{border-color:#4a9fd8;background:#ebf5fb}.import-dropzone.loading{cursor:default;opacity:.7}.dropzone-icon{color:#9ca3af;margin-bottom:16px}.import-dropzone:hover .dropzone-icon,.import-dropzone.active .dropzone-icon{color:#4a9fd8}.dropzone-title{font-size:15px;font-weight:500;color:#374151;margin-bottom:6px}.dropzone-hint{font-size:13px;color:#9ca3af}.dropzone-link{color:#4a9fd8;font-weight:500}.import-error{margin-top:16px;padding:12px 16px;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;font-size:14px;color:#ef4444}.import-result-card{margin-top:24px;background:#fff;border:1px solid #E8EAED;border-radius:12px;overflow:hidden}.import-result-header{padding:16px 20px;font-size:14px;font-weight:600;color:#111827;border-bottom:1px solid #E8EAED;background:#f9fafb}.import-result-stats{display:flex;gap:1px;background:#e8eaed}.result-stat-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:20px 16px;background:#fff}.result-stat-item.success .result-stat-num{color:#10b981}.result-stat-item.skipped .result-stat-num{color:#f59e0b}.result-stat-item.errors .result-stat-num{color:#ef4444}.result-stat-num{font-size:32px;font-weight:700;line-height:1;margin-bottom:6px}.result-stat-label{font-size:12px;color:#6b7280}.import-errors-list{padding:16px 20px;border-top:1px solid #E8EAED}.import-errors-title{font-size:13px;font-weight:600;color:#ef4444;margin-bottom:8px}.import-errors-list ul{list-style:disc;padding-left:20px;font-size:13px;color:#6b7280;line-height:1.7}.dict-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5}.dict-page .page-topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0}.dict-page .page-topbar-left{display:flex;align-items:center;gap:8px}.dict-page .page-breadcrumb-project{font-size:14px;color:#888}.dict-page .page-breadcrumb-sep{color:#888}.dict-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.dict-content{flex:1;overflow:auto;padding:24px;display:flex;justify-content:center}.dict-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,480px));gap:20px;width:100%;max-width:1000px;align-content:start}.dict-card{background:#fff;border:1px solid #E8EAED;border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.dict-card-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid #E8EAED}.dict-card-icon{flex-shrink:0}.dict-card-titles{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.dict-card-title{font-size:14px;font-weight:700;color:#1a1a1a}.dict-card-subtitle{font-size:11px;color:#9ca3af}.dict-card-count{flex-shrink:0;font-size:11px;font-weight:600;color:#666;background:#f3f4f6;padding:3px 8px;border-radius:10px}.dict-card-add{display:flex;align-items:center;gap:8px;padding:8px 20px;background:#f9fafb;border-bottom:1px solid #F3F4F6}.dict-color-picker{width:28px;height:28px;border:2px solid #E8EAED;border-radius:6px;padding:0;cursor:pointer;flex-shrink:0;background:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.dict-color-picker::-webkit-color-swatch-wrapper{padding:2px}.dict-color-picker::-webkit-color-swatch{border:none;border-radius:3px}.dict-add-icon{color:#9ca3af;flex-shrink:0}.dict-add-input{flex:1;height:30px;padding:0 10px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none}.dict-add-input:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}.dict-add-btn{height:30px;padding:0 12px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.dict-add-btn:hover{background:#333}.dict-add-btn:disabled{opacity:.4;cursor:not-allowed}.dict-card-error{padding:6px 20px;background:#fef2f2;color:#ef4444;font-size:12px}.dict-card-list{flex:1;overflow-y:auto;max-height:400px}.dict-card-row{display:flex;align-items:center;gap:12px;height:46px;padding:0 20px;border-bottom:1px solid #F3F4F6;transition:background .1s}.dict-card-row:last-child{border-bottom:none}.dict-card-row:hover{background:#fafbfc}.dict-card-row.editing{background:#ebf5fb}.dict-row-dot{width:8px;height:8px;border-radius:4px;flex-shrink:0}.dict-row-name{font-size:13px;font-weight:500;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dict-row-spacer{flex:1}.dict-row-count{font-size:10px;font-weight:500;padding:2px 7px;border-radius:8px;white-space:nowrap;flex-shrink:0}.dict-row-edit-input{flex:1;height:30px;padding:0 10px;font-size:13px;border:1.5px solid #4A9FD8;border-radius:6px;background:#fff;color:#111827;outline:none;box-shadow:0 0 0 3px #4a9fd81f}.dict-row-icon-btn{width:28px;height:28px;border:none;border-radius:6px;background:none;color:#d1d5db;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:all .1s;opacity:0}.dict-card-row:hover .dict-row-icon-btn,.dict-card-row.editing .dict-row-icon-btn{opacity:1}.dict-row-icon-btn:hover{background:#f3f4f6;color:#374151}.dict-row-icon-btn.danger:hover{background:#fef2f2;color:#ef4444}.dict-row-icon-btn.ok{color:#10b981;opacity:1}.dict-row-icon-btn.ok:hover{background:#ecfdf5}.dict-card-empty{padding:32px 20px;text-align:center;color:#9ca3af;font-size:13px}.aud-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5}.aud-page .page-topbar{display:flex;align-items:center;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0}.aud-page .page-topbar-left{display:flex;align-items:center;gap:8px}.aud-page .page-breadcrumb-project{font-size:14px;color:#888}.aud-page .page-breadcrumb-sep{color:#888}.aud-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.aud-content{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;gap:12px;min-height:0}.aud-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.aud-filter-select{height:34px;padding:0 28px 0 10px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.aud-filter-select:focus{border-color:#4a9fd8}.aud-filter-input{height:34px;width:140px;padding:0 10px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none}.aud-filter-input:focus{border-color:#4a9fd8}.aud-filter-date{height:34px;width:130px;padding:0 8px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none}.aud-filter-sep{color:#9ca3af;font-size:12px}.aud-reset-btn{display:flex;align-items:center;gap:4px;height:34px;padding:0 10px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#666;font-size:11px;cursor:pointer}.aud-reset-btn:hover{background:#f9fafb}.aud-total{font-size:12px;color:#9ca3af}.aud-card{background:#fff;border:1px solid #E8EAED;border-radius:12px;overflow:hidden;flex:1;display:flex;flex-direction:column;min-height:0}.aud-loading{padding:8px 20px;font-size:12px;color:#9ca3af;background:#f9fafb;border-bottom:1px solid #E8EAED}.aud-table-wrap{flex:1;overflow:auto}.aud-header{display:flex;height:38px;background:#f7f8fa;border-bottom:1px solid #E8EAED;font-size:11px;font-weight:600;color:#888;text-transform:uppercase;position:sticky;top:0;z-index:2}.aud-header>div{display:flex;align-items:center;padding:0 12px}.aud-row{display:flex;min-height:44px;border-bottom:1px solid #F3F4F6;align-items:center;transition:background .1s}.aud-row:last-child{border-bottom:none}.aud-row:hover{background:#fafbfc}.aud-row.clickable{cursor:pointer}.aud-row.clickable:hover{background:#ebf5fb}.aud-row.expanded{background:#f9fafb}.aud-row>div{padding:8px 12px;font-size:12px}.aud-col-time{width:140px;flex-shrink:0;color:#9ca3af;white-space:nowrap}.aud-col-user{width:140px;flex-shrink:0;color:#374151;font-weight:500}.aud-col-action{width:140px;flex-shrink:0}.aud-col-entity{width:220px;flex-shrink:0;color:#666;overflow:hidden;text-overflow:ellipsis}.aud-col-details{flex:1;min-width:0;color:#666}.aud-action-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;white-space:nowrap}.aud-entity-link{color:#4a9fd8;cursor:pointer}.aud-entity-link:hover{text-decoration:underline}.aud-details-preview{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;font-size:11px;color:#9ca3af}.aud-details-exp{display:flex;flex-direction:column;gap:4px}.aud-detail-row{display:flex;gap:8px;font-size:12px}.aud-detail-k{font-weight:600;color:#888;min-width:100px;flex-shrink:0}.aud-muted{color:#d1d5db}.aud-empty{padding:40px;text-align:center;color:#9ca3af;font-size:13px}.aud-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid #E8EAED;flex-shrink:0}.aud-page-sizes{display:flex;gap:4px}.aud-ps-btn{height:28px;padding:0 10px;border:1px solid #E8EAED;border-radius:4px;background:#fff;color:#666;font-size:11px;cursor:pointer}.aud-ps-btn.active{background:#1a1a1a;border-color:#1a1a1a;color:#fff}.aud-pagination{display:flex;align-items:center;gap:4px}.aud-pg-btn{width:28px;height:28px;border:1px solid #E8EAED;border-radius:4px;background:#fff;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center}.aud-pg-btn:disabled{opacity:.3;cursor:not-allowed}.aud-pg-btn:hover:not(:disabled){background:#f9fafb}.aud-pg-current{font-size:12px;font-weight:500;color:#374151;min-width:50px;text-align:center}.members-page{max-width:800px;margin:0 auto}.members-page--sides{max-width:1100px}.add-member-row{display:flex;gap:8px;align-items:flex-start}.add-member-search{flex:1;position:relative}.search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-overlay);z-index:50;max-height:200px;overflow-y:auto}.search-item{padding:10px 12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:14px}.search-item:hover{background:var(--color-primary-light)}.search-login{font-size:12px;color:var(--color-text-subtle)}.sides-hint{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-subtle);margin-bottom:12px}.sides-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.side-panel{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color .2s,box-shadow .2s;min-height:200px}.side-panel--drop{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.side-panel-header{display:flex;align-items:center;gap:8px;padding:12px 16px;font-weight:600;font-size:15px;border-bottom:1px solid var(--color-border)}.side-panel-header--executor{color:var(--color-primary)}.side-panel-header--customer{color:#e67e22}.side-panel-count{background:var(--color-bg);padding:1px 8px;border-radius:10px;font-size:12px;font-weight:500;color:var(--color-text-subtle);margin-left:auto}.side-panel-body{padding:8px;display:flex;flex-direction:column;gap:4px}.side-panel-empty{text-align:center;color:var(--color-text-subtle);padding:32px 16px;font-size:14px}.member-card{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius);background:var(--color-bg);cursor:grab;transition:opacity .2s,box-shadow .15s;border:1px solid transparent}.member-card:hover{border-color:var(--color-border);box-shadow:0 1px 3px #0000000f}.member-card:active{cursor:grabbing}.member-card--dragging{opacity:.4}.member-card-grip{flex-shrink:0;cursor:grab;padding:2px}.member-card-info{flex:1;min-width:0}.member-card-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-card-login{font-size:12px;color:var(--color-text-subtle)}.member-card-role{width:auto;min-width:130px;font-size:13px;flex-shrink:0}@media (max-width: 768px){.sides-grid{grid-template-columns:1fr}.members-page--sides{max-width:100%}}.debug-page{max-width:700px;margin:0 auto}.debug-warning{background:#fffae6;border:1px solid var(--color-warning);color:#ff8b00;padding:12px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;margin-bottom:24px}.debug-actions{display:flex;flex-direction:column;gap:16px}.debug-card h3{font-size:16px;margin-bottom:8px}.debug-card p{font-size:14px;color:var(--color-text-subtle);margin-bottom:16px}.debug-result{margin-top:20px;padding:12px 16px;border-radius:var(--radius);font-size:14px;font-weight:500}.debug-result.success{background:#e3fcef;color:var(--color-success)}.debug-result.error{background:#ffebe6;color:var(--color-danger)}.workflow-page{max-width:1100px;margin:0 auto}.workflow-page{--wf-canvas-bg: #1a1d23;--wf-grid: rgba(255,255,255,.06);--wf-node-bg: #23272e;--wf-node-border: rgba(255,255,255,.1);--wf-node-label: rgba(255,255,255,.45);--wf-node-value: rgba(255,255,255,.85);--wf-arrow: rgba(255,255,255,.3);--wf-toggle-off: rgba(255,255,255,.15)}.workflow-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.wf-mode-hint{font-size:13px;color:var(--color-text-subtle);line-height:1.4}.wf-port-hint{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--color-primary);vertical-align:middle;margin:0 2px}.wf-canvas{background:var(--wf-canvas-bg);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:20px;border:1px solid var(--wf-node-border)}.workflow-svg{display:block}.workflow-svg text{-webkit-user-select:none;user-select:none;pointer-events:none}.wf-arrow{cursor:pointer}.wf-arrow:hover path:last-child{stroke:var(--color-danger);stroke-width:2.5}.wf-port{opacity:0;transition:opacity .15s}g:hover>.wf-port{opacity:1}.workflow-columns{padding:20px}.workflow-columns h3{font-size:18px;margin-bottom:4px}.column-list{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.column-row{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--color-bg);border-radius:var(--radius)}.column-order-btns{display:flex;flex-direction:column;gap:1px}.column-order-btns .btn-icon{width:22px;height:18px;font-size:12px}.column-color-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.column-label{font-weight:600;font-size:14px;flex:1}.column-key{font-size:11px;color:var(--color-text-subtle);margin-right:4px}.column-work-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:4px;background:var(--color-primary);color:#fff;margin-right:4px}.column-edit-input{flex:1;padding:4px 8px;font-size:14px}.column-color-input{width:32px;height:32px;border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;padding:1px}.add-column-form{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--color-border)}.add-column-form .form-input{flex:1}.wf-toast{position:fixed;bottom:24px;right:24px;z-index:300;padding:10px 20px;border-radius:var(--radius-lg);font-size:14px;font-weight:500;box-shadow:var(--shadow-overlay);cursor:pointer;animation:wf-toast-in .25s ease-out}.wf-toast-success{background:#e3fcef;border-left:4px solid var(--color-success);color:var(--color-success)}.wf-toast-error{background:#ffebe6;border-left:4px solid var(--color-danger);color:var(--color-danger)}@keyframes wf-toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.prj-new-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:12px;font-weight:600;cursor:pointer}.prj-new-btn:hover{background:#333}.prj-del-btn{width:28px;height:28px;border:none;border-radius:6px;background:none;color:#d1d5db;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .1s}.adm-list-row:hover .prj-del-btn{opacity:1}.prj-del-btn:hover{background:#fef2f2;color:#ef4444}.wizard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#f0f2f5;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.wizard-container{display:flex;background:#fff;border-radius:12px;box-shadow:0 12px 40px #0000001f;width:100%;max-width:960px;min-height:520px;overflow:hidden}.wizard-sidebar{width:220px;flex-shrink:0;background:#f7f8fa;border-right:1px solid #E8EAED;padding:28px 16px;display:flex;flex-direction:column;gap:24px}.wizard-logo{font-size:16px;font-weight:700;color:#1a1a1a;padding:0 8px}.wizard-steps{display:flex;flex-direction:column;gap:4px}.wizard-step{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:default;font-size:13px;color:#9ca3af;transition:background .15s}.wizard-step--done{cursor:pointer;color:#374151}.wizard-step--done:hover{background:#ebf5fb}.wizard-step--active{color:#4a9fd8;font-weight:600}.wizard-step-num{width:26px;height:26px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:2px solid #E8EAED;color:#9ca3af;flex-shrink:0}.wizard-step--active .wizard-step-num{border-color:#4a9fd8;color:#4a9fd8}.wizard-step--done .wizard-step-num{border-color:#10b981;background:#10b981;color:#fff}.wizard-content{flex:1;padding:28px;display:flex;flex-direction:column;overflow:hidden}.wizard-panel{flex:1;overflow:auto}.wizard-panel h2{font-size:20px;font-weight:700;color:#1a1a1a;margin-bottom:4px}.wizard-hint{font-size:13px;color:#9ca3af;margin-bottom:20px}.wizard-field{margin-bottom:14px;display:flex;flex-direction:column;gap:5px}.wizard-field label{font-size:12px;font-weight:600;color:#6b7280}.wizard-input{padding:8px 12px;font-size:13px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;font-family:inherit}.wizard-input:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}textarea.wizard-input{resize:vertical;min-height:60px}.wizard-modules{display:grid;grid-template-columns:1fr 1fr;gap:8px}.wizard-module{display:flex;gap:10px;padding:10px 12px;border:1.5px solid #E8EAED;border-radius:8px;cursor:pointer;transition:all .15s;align-items:flex-start;font-size:12px}.wizard-module:hover{border-color:#b8d9ef}.wizard-module.active{border-color:#4a9fd8;background:#ebf5fb}.wizard-module strong{display:block;font-size:13px;color:#1a1a1a}.wizard-module span{color:#9ca3af;font-size:11px}.wizard-module input{margin-top:2px;accent-color:#4A9FD8}.wizard-dropdown{position:absolute;top:100%;left:0;right:0;z-index:10;background:#fff;border:1px solid #E8EAED;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto}.wizard-dropdown-item{padding:8px 12px;cursor:pointer;font-size:13px}.wizard-dropdown-item:hover{background:#f9fafb}.wizard-dropdown-item span{color:#9ca3af;font-size:12px;margin-left:6px}.wizard-team-row{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px}.wizard-team-row span:first-child{flex:1;font-weight:500}.wizard-nav{display:flex;justify-content:space-between;margin-top:24px;padding-top:16px;border-top:1px solid #E8EAED}.wizard-btn-back{height:36px;padding:0 16px;border:1px solid #E8EAED;border-radius:6px;background:#f7f8fa;color:#666;font-size:13px;cursor:pointer}.wizard-btn-next{height:36px;padding:0 20px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.wizard-btn-next:disabled{opacity:.4;cursor:not-allowed}.prj-portfolio-badge{display:inline-block;padding:2px 8px;background:#ede9fe;color:#6d28d9;border-radius:12px;font-size:11px;font-weight:500}.prj-group-header{display:flex;align-items:center;gap:8px;padding:14px 0 6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;border-bottom:1px solid #E8EAED;margin-bottom:0}.prj-group-icon{display:inline-block;width:10px;height:10px;border-radius:3px;flex-shrink:0}.prj-group-count{margin-left:auto;background:#f3f4f6;color:#9ca3af;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;letter-spacing:0;text-transform:none}.prj-row-indented{padding-left:18px!important}.pfcard-list{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.pfcard-row{display:flex;align-items:center;gap:6px;padding:4px 0}.pfcard-name{flex:1;font-size:13px;font-weight:500;color:#1a1a1a}.pfcard-input{flex:1;height:30px;font-size:13px}.pfcard-add{display:flex;gap:8px;align-items:center}.pf-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:2px solid #E8EAED;padding-bottom:0}.pf-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:500;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;font-family:inherit}.pf-tab:hover{color:#1a1a1a}.pf-tab.active{color:#1a1a1a;border-bottom-color:#1a1a1a}.pf-tab-count{background:#f3f4f6;color:#9ca3af;font-size:11px;font-weight:600;padding:1px 6px;border-radius:10px}.pf-tab.active .pf-tab-count{background:#1a1a1a;color:#fff}.pf-add-row{display:flex;gap:8px;align-items:flex-start;padding:0 0 16px;margin-bottom:4px;border-bottom:1px solid #F0F2F5}.pf-search-input{width:100%;height:36px}.pf-search-dropdown{position:absolute;top:100%;left:0;right:0;z-index:20;background:#fff;border:1px solid #E8EAED;border-radius:8px;box-shadow:0 4px 16px #0000001a;max-height:240px;overflow-y:auto;margin-top:2px}.pf-search-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .12s}.pf-search-item:hover{background:#f9fafb}.pf-search-name{font-size:13px;font-weight:500;color:#1a1a1a;display:block}.pf-search-login{font-size:11px;color:#9ca3af;display:block}.pf-role-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500}.pf-role-badge--admin{background:#ede9fe;color:#6d28d9}.pf-role-badge--member{background:#f3f4f6;color:#6b7280}.settings-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5}.settings-page .page-topbar{display:flex;align-items:center;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0}.settings-page .page-topbar-left{display:flex;align-items:center;gap:8px}.settings-page .page-breadcrumb-project{font-size:14px;color:#888}.settings-page .page-breadcrumb-sep{color:#888}.settings-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.sett-layout{flex:1;display:flex;min-height:0;overflow:hidden}.sett-sidebar{width:200px;flex-shrink:0;background:#fff;border-right:1px solid #E8EAED;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.sett-tab{display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;background:none;border-radius:6px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .15s;font-family:inherit;text-align:left}.sett-tab:hover{background:#f9fafb;color:#374151}.sett-tab.active{background:#1a1a1a;color:#fff}.sett-content{flex:1;overflow-y:auto;padding:24px;min-width:0}.sett-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;font-size:13px;color:#ef4444;margin-bottom:16px}.sett-error button{border:none;background:none;cursor:pointer;color:#ef4444}.sett-card{background:#fff;border:1px solid #E8EAED;border-radius:12px;overflow:hidden;margin-bottom:16px}.sett-card-head{padding:16px 20px;border-bottom:1px solid #E8EAED;display:flex;flex-direction:column;gap:2px}.sett-card-title{font-size:15px;font-weight:700;color:#1a1a1a}.sett-card-desc{font-size:12px;color:#9ca3af}.sett-card-body{padding:20px;display:flex;flex-direction:column;gap:16px}.sett-field{display:flex;flex-direction:column;gap:6px}.sett-field label{font-size:12px;font-weight:600;color:#6b7280}.sett-field input,.sett-field textarea,.sett-field select{padding:8px 12px;font-size:13px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;font-family:inherit}.sett-field input:focus,.sett-field textarea:focus,.sett-field select:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}.sett-field input:disabled,.sett-field textarea:disabled,.sett-field select:disabled{background:#f9fafb;color:#9ca3af}.sett-field textarea{resize:vertical;min-height:60px}.sett-field select{cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.sett-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.sett-save-btn{display:flex;align-items:center;gap:6px;padding:8px 20px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.sett-save-btn:hover{background:#333}.sett-template-btn{padding:8px 16px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text);font-size:13px;cursor:pointer;transition:border-color .15s}.sett-template-btn:hover{border-color:#4a9fd8;color:#4a9fd8}.sett-template-form{margin-top:16px;padding:16px;background:var(--color-bg);border-radius:8px;border:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px}.sett-template-form-title{font-size:13px;font-weight:600;color:var(--color-text)}.sett-template-form-actions{display:flex;gap:8px;justify-content:flex-end}.sett-template-success{font-size:12px;color:#10b981;font-weight:500;text-align:right}.sett-danger-zone{margin-top:24px;padding:16px;border:1px solid #FECACA;border-radius:8px;background:#fff5f5}.sett-danger-title{font-size:11px;font-weight:700;color:#ef4444;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}.sett-danger-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.sett-danger-label{font-size:13px;font-weight:600;color:#374151}.sett-danger-desc{font-size:12px;color:#6b7280;margin-top:2px}.sett-danger-btn{flex-shrink:0;padding:6px 14px;border-radius:6px;border:1px solid #EF4444;background:#fff;color:#ef4444;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.sett-danger-btn:hover{background:#ef4444;color:#fff}.sett-danger-btn--unarchive{border-color:#10b981;color:#10b981}.sett-danger-btn--unarchive:hover{background:#10b981;color:#fff}.sett-modules-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:#e8eaed}.sett-module{display:flex;align-items:flex-start;gap:12px;padding:14px 20px;background:#fff;cursor:pointer;transition:background .15s}.sett-module:hover{background:#fafbfc}.sett-module.active{background:#f0f9ff}.sett-module-toggle{width:36px;height:20px;border-radius:10px;background:#e8eaed;position:relative;flex-shrink:0;margin-top:2px;transition:background .2s}.sett-module-toggle.on{background:#10b981}.sett-module-dot{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:8px;background:#fff;transition:left .2s;box-shadow:0 1px 3px #00000026}.sett-module-toggle.on .sett-module-dot{left:18px}.sett-module-text{display:flex;flex-direction:column;gap:2px}.sett-module-name{font-size:13px;font-weight:600;color:#1a1a1a}.sett-module-desc{font-size:11px;color:#9ca3af;line-height:1.4}.sett-field-group{padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid #F3F4F6}.sett-field-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.sett-field-group-title{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.sett-field-items{display:flex;flex-wrap:wrap;gap:8px}.sett-field-check{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;font-size:12px;color:#374151;cursor:pointer;border:1px solid #E8EAED;background:#fff;transition:all .15s;-webkit-user-select:none;user-select:none}.sett-field-check:hover{background:#f9fafb}.sett-field-check.checked{background:#ebf5fb;border-color:#b8d9ef;color:#1a6fa8}.sett-field-check.locked{opacity:.5;cursor:default}.sett-field-check input{accent-color:#4A9FD8;cursor:pointer}.sett-roles-list{display:flex;flex-direction:column}.sett-role{padding:14px 20px;border-bottom:1px solid #F3F4F6;transition:background .1s}.sett-role:last-child{border-bottom:none}.sett-role.editing{background:#ebf5fb}.sett-role-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.sett-role-name{font-size:14px;font-weight:600;color:#1a1a1a}.sett-role-badge{font-size:10px;font-weight:600;color:#9ca3af;background:#f3f4f6;padding:2px 7px;border-radius:4px}.sett-role-spacer{flex:1}.sett-role-input{flex:1;height:32px;padding:0 10px;font-size:13px;border:1.5px solid #4A9FD8;border-radius:6px;background:#fff;color:#1a1a1a;outline:none}.sett-icon-btn{width:28px;height:28px;border:none;border-radius:6px;background:none;color:#d1d5db;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;opacity:0}.sett-role:hover .sett-icon-btn,.sett-role.editing .sett-icon-btn{opacity:1}.sett-icon-btn:hover{background:#f3f4f6;color:#374151}.sett-icon-btn.danger:hover{background:#fef2f2;color:#ef4444}.sett-icon-btn.ok{color:#10b981;opacity:1}.sett-icon-btn.ok:hover{background:#ecfdf5}.sett-perms{display:flex;gap:6px;flex-wrap:wrap}.sett-perm-badge{font-size:11px;padding:3px 8px;border-radius:6px;background:#ecfdf5;color:#10b981;font-weight:500}.sett-perm-check{display:flex;align-items:center;gap:4px;font-size:11px;color:#374151;cursor:pointer;padding:3px 8px;border-radius:6px;border:1px solid #E8EAED;background:#fff;transition:all .15s;-webkit-user-select:none;user-select:none}.sett-perm-check:hover{background:#f9fafb}.sett-perm-check.checked{background:#ecfdf5;border-color:#a7f3d0}.sett-perm-check input{accent-color:#10B981;cursor:pointer}.sett-role-add{border-top:1px solid #E8EAED}.sett-role-add-head{display:flex;align-items:center;gap:8px;padding:12px 20px;color:#9ca3af}.sett-role-add-input{flex:1;height:32px;padding:0 10px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none}.sett-role-add-input:focus{border-color:#4a9fd8}.sett-role-add-btn{height:32px;padding:0 14px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap}.sett-role-add-btn:disabled{opacity:.4;cursor:not-allowed}.sett-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:300;display:flex;align-items:center;justify-content:center}.sett-confirm{width:420px;background:#fff;border-radius:12px;box-shadow:0 12px 32px #00000026;overflow:hidden}.sett-confirm-head{padding:16px 20px;font-size:15px;font-weight:700;color:#1a1a1a;border-bottom:1px solid #E8EAED}.sett-confirm-body{padding:20px}.sett-confirm-warn{background:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:12px 14px;font-size:13px;color:#ef4444;line-height:1.5}.sett-confirm-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.sett-confirm-cancel{height:36px;padding:0 16px;border:1px solid #E8EAED;border-radius:6px;background:#f7f8fa;color:#666;font-size:13px;cursor:pointer}.sett-confirm-danger{height:36px;padding:0 16px;border:none;border-radius:6px;background:#ef4444;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.sett-confirm-danger:hover{background:#dc2626}.pp-embed{display:flex;flex-direction:column;gap:16px}.pp-header{display:flex;align-items:center;gap:16px;padding:20px}.pp-logo{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0}.pp-header-info{flex:1;display:flex;flex-direction:column;gap:2px}.pp-name{font-size:16px;font-weight:700;color:#1a1a1a}.pp-slug{font-size:12px;color:#9ca3af}.pp-date{font-size:11px;color:#9ca3af}.pp-stats{display:flex;gap:20px;flex-shrink:0}.pp-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.pp-stat-val{font-size:22px;font-weight:700;color:#1a1a1a;line-height:1}.pp-stat-lbl{font-size:10px;color:#9ca3af}.pp-statuses{padding:0 20px 16px;display:flex;flex-direction:column;gap:6px}.pp-status-row{display:flex;align-items:center;gap:8px;font-size:12px}.pp-status-dot{width:8px;height:8px;border-radius:4px;flex-shrink:0}.pp-status-name{width:100px;color:#374151;flex-shrink:0}.pp-status-bar{flex:1;height:6px;background:#f3f4f6;border-radius:3px;overflow:hidden}.pp-status-bar div{height:100%;border-radius:3px;transition:width .3s}.pp-status-cnt{width:28px;text-align:right;font-weight:600;color:#1a1a1a}.pp-members{display:flex;flex-direction:column}.pp-member{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid #F3F4F6}.pp-member:last-child{border-bottom:none}.pp-member-avatar{width:30px;height:30px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.pp-member-info{flex:1;display:flex;flex-direction:column;gap:1px}.pp-member-name{font-size:13px;font-weight:500;color:#1a1a1a}.pp-member-login{font-size:11px;color:#9ca3af}.pp-member-role{font-size:11px;color:#666;background:#f3f4f6;padding:2px 8px;border-radius:4px}.pp-member-side{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:500}.pp-member-side.customer{background:#ebf5fb;color:#4a9fd8}.pp-member-side.executor{background:#ecfdf5;color:#10b981}.pp-desc-body{padding:16px 20px}.pp-desc-text{font-size:13px;line-height:1.6;color:#374151}.pp-desc-text p{margin:0 0 6px}.pp-desc-empty{color:#9ca3af;font-size:13px;font-style:italic}.pp-desc-textarea{width:100%;padding:10px 12px;font-size:13px;line-height:1.6;border:1px solid #E8EAED;border-radius:6px;font-family:inherit;outline:none;resize:vertical;color:#111827}.pp-desc-textarea:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}.pp-desc-actions{display:flex;gap:8px;margin-top:10px}.pp-save-btn{padding:6px 16px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:12px;font-weight:600;cursor:pointer}.pp-cancel-btn{padding:6px 16px;border:1px solid #E8EAED;border-radius:6px;background:#f7f8fa;color:#666;font-size:12px;cursor:pointer}.pp-edit-btn,.pp-upload-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#374151;font-size:11px;font-weight:500;cursor:pointer}.pp-edit-btn:hover,.pp-upload-btn:hover{background:#f9fafb}.pp-dropzone{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 20px 12px;padding:14px;border:2px dashed #E8EAED;border-radius:8px;color:#9ca3af;font-size:12px;transition:all .15s}.pp-dropzone.active{border-color:#4a9fd8;background:#ebf5fb;color:#4a9fd8}.pp-files{display:flex;flex-direction:column}.pp-file{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid #F3F4F6}.pp-file:last-child{border-bottom:none}.pp-file-icon{font-size:20px;flex-shrink:0}.pp-file-info{flex:1;display:flex;flex-direction:column;gap:2px}.pp-file-name{font-size:13px;font-weight:500;color:#4a9fd8;text-decoration:none}.pp-file-name:hover{text-decoration:underline}.pp-file-meta{font-size:11px;color:#9ca3af}.pp-file-del{width:28px;height:28px;border:none;border-radius:6px;background:none;color:#d1d5db;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .1s}.pp-file:hover .pp-file-del{opacity:1}.pp-file-del:hover{background:#fef2f2;color:#ef4444}.pp-files-empty{padding:24px 20px;text-align:center;color:#9ca3af;font-size:13px}.trash-list{display:flex;flex-direction:column;gap:0}.trash-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #F3F4F6}.trash-row:last-child{border-bottom:none}.trash-id{font-size:11px;font-weight:600;color:#9ca3af;flex-shrink:0;min-width:64px}.trash-subject{flex:1;font-size:13px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trash-meta{font-size:11px;color:#9ca3af;flex-shrink:0}.trash-date{font-size:11px;color:#c0c4cc;flex-shrink:0;min-width:80px;text-align:right}.trash-actions{display:flex;gap:4px;flex-shrink:0}.trash-actions .sett-icon-btn{opacity:1}@media (max-width: 768px){.sett-layout{flex-direction:column}.sett-sidebar{width:100%;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid #E8EAED;padding:8px}.sett-modules-grid{grid-template-columns:1fr}}.adm-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5}.adm-page .page-topbar{display:flex;align-items:center;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0}.adm-page .page-topbar-left{display:flex;align-items:center;gap:8px}.adm-page .page-breadcrumb-project{font-size:14px;color:#888}.adm-page .page-breadcrumb-sep{color:#888}.adm-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.adm-content{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.adm-error{padding:10px 14px;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;font-size:13px;color:#ef4444}.adm-card{background:#fff;border:1px solid #E8EAED;border-radius:12px;overflow:visible}.adm-card-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid #E8EAED}.adm-card-titles{display:flex;flex-direction:column;gap:1px}.adm-card-title{font-size:14px;font-weight:700;color:#1a1a1a}.adm-card-desc{font-size:11px;color:#9ca3af}.adm-add-row{display:flex;gap:8px;padding:14px 20px;flex-wrap:wrap;align-items:center}.adm-select{height:34px;flex:1 1 160px;min-width:150px;padding:0 28px 0 10px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.adm-select:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}.adm-select-sm{flex:0;min-width:120px}.adm-add-btn{height:34px;padding:0 16px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}.adm-add-btn:disabled{opacity:.4;cursor:not-allowed}.adm-add-btn:hover:not(:disabled){background:#333}.adm-card .adm-list{overflow:hidden;border-radius:0 0 12px 12px}.adm-card .adm-card-head{border-radius:12px 12px 0 0}.adm-list-header{display:flex;align-items:center;height:36px;padding:0 20px;background:#f7f8fa;border-bottom:1px solid #E8EAED;font-size:11px;font-weight:600;color:#888;text-transform:uppercase}.adm-list-row{display:flex;align-items:center;height:52px;padding:0 20px;border-bottom:1px solid #F3F4F6;transition:background .1s}.adm-list-row:last-child{border-bottom:none}.adm-list-row:hover{background:#fafbfc}.adm-col-user{flex:1;display:flex;align-items:center;gap:10px;min-width:0}.adm-col-role{width:160px;flex-shrink:0}.adm-col-date{width:100px;flex-shrink:0;font-size:12px;color:#9ca3af}.adm-avatar{width:30px;height:30px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.adm-user-info{display:flex;flex-direction:column;gap:1px;min-width:0}.adm-user-name{font-size:13px;font-weight:500;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.adm-user-login{font-size:11px;color:#9ca3af}.adm-role-select{height:30px;padding:0 24px 0 8px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.adm-col-portfolios{flex:1;display:flex;align-items:center;gap:5px;flex-wrap:wrap;min-width:0}.adm-col-actions{width:72px;flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;gap:4px}.usr-pf-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 7px 2px 5px;border-radius:20px;font-size:11px;font-weight:500;border:1px solid transparent;white-space:nowrap}.usr-pf-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.usr-pf-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;border:none;background:none;cursor:pointer;padding:0;opacity:.4;border-radius:50%}.usr-pf-chip-remove:hover{opacity:1;background:#0000001a}.usr-pf-chip-role{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;border:none;background:none;cursor:pointer;padding:0;opacity:.5;border-radius:50%}.usr-pf-chip-role:hover{opacity:1;background:#0000001a}.usr-pf-role-badge{font-size:9px;font-weight:600;opacity:.6;letter-spacing:.02em}.usr-pf-add-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border:1px dashed #D1D5DB;border-radius:50%;background:none;cursor:pointer;color:#9ca3af}.usr-pf-add-btn:hover{border-color:#4a9fd8;color:#4a9fd8;background:#eff6ff}.usr-pf-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid #E8EAED;border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:200;overflow:hidden;min-width:160px}.usr-pf-drop-role-row{padding:6px 8px;border-bottom:1px solid #F3F4F6}.usr-pf-drop-role-row .adm-select{width:100%}.usr-pf-drop-item{display:flex;align-items:center;gap:7px;padding:7px 12px;font-size:12px;cursor:pointer;color:#111827}.usr-pf-drop-item:hover{background:#f3f4f6}.adm-reset-popover{display:flex;align-items:center;gap:4px}.adm-reset-input{height:28px;width:130px;padding:0 8px;font-size:12px;border:1px solid #4A9FD8;border-radius:6px;outline:none;background:#fff;color:#111827}.adm-reset-ok{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:6px;background:#10b981;color:#fff;cursor:pointer}.adm-reset-ok:disabled{opacity:.4;cursor:not-allowed}.adm-reset-cancel{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#6b7280;cursor:pointer}.pf-access-list{display:flex;flex-direction:column}.pf-access-row{border-bottom:1px solid #F3F4F6}.pf-access-row:last-child{border-bottom:none}.pf-access-header{display:flex;align-items:center;gap:10px;padding:10px 20px;min-height:48px}.pf-access-icon{display:inline-block;width:10px;height:10px;border-radius:3px;flex-shrink:0}.pf-access-name{font-size:13px;font-weight:600;color:#1a1a1a;white-space:nowrap;flex-shrink:0;min-width:120px}.pf-access-chips{display:flex;flex-wrap:wrap;gap:5px;flex:1;align-items:center}.pf-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px 3px 4px;border-radius:20px;font-size:11px;font-weight:500;white-space:nowrap}.pf-chip--admin{background:#ede9fe;color:#6d28d9}.pf-chip--member{background:#f3f4f6;color:#374151}.pf-chip-avatar{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:8px;font-weight:700;color:#fff;flex-shrink:0}.pf-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border:none;background:none;cursor:pointer;border-radius:50%;color:inherit;opacity:.5;padding:0;margin-left:2px}.pf-chip-remove:hover{opacity:1;background:#0000001a}.pf-chip-empty{font-size:11px;color:#c4c9d4;font-style:italic}.pf-access-add-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid #E8EAED;border-radius:6px;background:#fff;cursor:pointer;color:#6b7280;flex-shrink:0;margin-left:auto}.pf-access-add-btn:hover{background:#f3f4f6;border-color:#9ca3af}.pf-access-search{display:flex;gap:8px;padding:8px 20px 12px;align-items:flex-start}.pf-search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.pf-search-field{width:100%;height:32px;padding:0 10px 0 30px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;outline:none;background:#fff;color:#111827}.pf-search-field:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}.pf-inline-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #E8EAED;border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:100;overflow:hidden}.pf-inline-item{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;font-size:12px}.pf-inline-item:hover{background:#f3f4f6}.gantt-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5}.gantt-page .page-topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0;gap:16px}.gantt-page .page-topbar-left{display:flex;align-items:center;gap:8px}.gantt-page .page-breadcrumb-project{font-size:14px;color:#888}.gantt-page .page-breadcrumb-sep{color:#888}.gantt-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.gantt-toolbar{display:flex;align-items:center;gap:12px;padding:10px 24px;background:#fff;border-bottom:1px solid #E8EAED;flex-shrink:0;flex-wrap:wrap}.gantt-toolbar-label{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em}.gantt-status-checks{display:flex;gap:6px;align-items:center}.gantt-status-pill{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;border:1px solid #E8EAED;background:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.gantt-status-pill:hover{background:#f9fafb}.gantt-status-pill.active{background:#1a1a1a;border-color:#1a1a1a;color:#fff}.gantt-status-pill .status-dot{width:8px;height:8px;border-radius:4px}.gantt-toolbar-sep{width:1px;height:20px;background:#e8eaed;flex-shrink:0}.gantt-filter-select{height:32px;padding:0 28px 0 10px;font-size:12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.gantt-filter-select:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd826}.gantt-toolbar-spacer{flex:1}.gantt-today-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#374151;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.gantt-today-btn:hover{background:#f9fafb}.gantt-container{flex:1;cursor:grab;overflow:auto;margin:16px 24px 24px;border:1px solid #E8EAED;border-radius:12px;background:#fff;min-height:0}.gantt-container.grabbing{cursor:grabbing;-webkit-user-select:none;user-select:none}.gantt-svg{display:block;min-width:100%}.gantt-svg text{-webkit-user-select:none;user-select:none;font-family:Inter,-apple-system,sans-serif}.gantt-ms-legend{display:flex;gap:10px;align-items:center}.gantt-ms-legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:#666}.gantt-ms-diamond{width:8px;height:8px;transform:rotate(45deg);border-radius:1px;flex-shrink:0}.gantt-add-ms-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.gantt-add-ms-btn:hover{background:#333}.gantt-ms-group{cursor:pointer}.gantt-ms-group:hover line{opacity:.9!important}.gantt-ms-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000026;z-index:300;display:flex;align-items:center;justify-content:center}.gantt-ms-popup{width:360px;background:#fff;border-radius:12px;box-shadow:0 12px 32px #00000026;overflow:hidden}.gantt-ms-popup-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;font-size:14px;font-weight:700;color:#1a1a1a;border-bottom:1px solid #E8EAED}.gantt-ms-popup-close{border:none;background:none;color:#9ca3af;cursor:pointer;border-radius:4px;padding:2px}.gantt-ms-popup-close:hover{background:#f3f4f6;color:#374151}.gantt-ms-popup-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}.gantt-ms-field{display:flex;flex-direction:column;gap:5px}.gantt-ms-field label{font-size:11px;font-weight:600;color:#888}.gantt-ms-field input{height:34px;padding:0 10px;font-size:13px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none}.gantt-ms-field input:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}.gantt-ms-types{display:flex;gap:6px}.gantt-ms-type-btn{flex:1;height:32px;border:1.5px solid #E8EAED;border-radius:6px;background:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.gantt-ms-type-btn.active{background:#f9fafb;font-weight:600}.gantt-ms-popup-footer{display:flex;gap:8px;padding:12px 20px;border-top:1px solid #E8EAED}.gantt-ms-cancel{flex:1;height:36px;border:1px solid #E8EAED;border-radius:6px;background:#f7f8fa;color:#666;font-size:13px;cursor:pointer}.gantt-ms-cancel:hover{background:#f0f2f5}.gantt-ms-save{flex:1;height:36px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.gantt-ms-save:hover{background:#333}.gantt-ms-save:disabled{opacity:.4;cursor:not-allowed}.gantt-empty{flex:1;display:flex;align-items:center;justify-content:center;margin:24px;background:#fff;border:1px solid #E8EAED;border-radius:12px;color:#9ca3af;font-size:14px}.chat-page{display:flex;flex-direction:column;flex:1;height:100%;min-height:0;overflow:hidden;background:#f0f2f5}.chat-topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0;gap:16px}.chat-topbar-left{display:flex;align-items:center;gap:8px}.chat-topbar-left .page-breadcrumb-project{font-size:14px;color:#888}.chat-topbar-left .page-breadcrumb-sep{color:#888}.chat-topbar-left .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.chat-topbar-right{display:flex;align-items:center;gap:12px}.chat-msg-count{font-size:12px;color:#9ca3af}.chat-read-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#374151;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.chat-read-btn:hover{background:#f9fafb}.chat-main{flex:1;min-height:0;display:flex;flex-direction:row;overflow:hidden}.chat-body{flex:1;min-height:0;overflow-y:auto;display:flex}.chat-messages{width:100%;max-width:800px;padding:16px 24px;display:flex;flex-direction:column;gap:2px}.chat-load-more{align-self:center;margin-bottom:8px;padding:6px 16px;border-radius:8px;border:1px solid #E8EAED;background:#fff;color:#374151;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.chat-load-more:hover:not(:disabled){background:#f3f4f6}.chat-load-more:disabled{opacity:.5;cursor:not-allowed}.chat-date-sep{display:flex;align-items:center;justify-content:center;padding:12px 0}.chat-date-sep span{font-size:11px;font-weight:600;color:#9ca3af;background:#f0f2f5;padding:4px 12px;border-radius:10px;text-transform:capitalize}.chat-msg{display:flex;align-items:flex-start;gap:8px;padding:4px 0;position:relative}.chat-msg.own{flex-direction:row-reverse}.chat-msg.own .chat-reply-btn{order:-1}.chat-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;margin-top:2px}.chat-bubble{max-width:520px;min-width:80px;background:#fff;border:1px solid #E8EAED;border-radius:4px 12px 12px;padding:8px 12px;position:relative}.chat-msg.own .chat-bubble{background:#ebf5fb;border-color:#b8d9ef;border-radius:12px 4px 12px 12px}.chat-bubble-author{font-size:12px;font-weight:600;color:#4a9fd8;margin-bottom:2px}.chat-msg.own .chat-bubble-author{color:#3a8fc8;text-align:right}.chat-bubble-body{font-size:14px;line-height:1.5;color:#111827;word-break:break-word}.chat-bubble-body img{display:block;max-width:100%;border-radius:6px;margin:6px 0 2px}.chat-bubble-body .msg-file-link{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f7f8fa;border:1px solid #E8EAED;border-radius:8px;text-decoration:none;color:#111827;font-size:13px;margin:6px 0 2px}.chat-msg.own .chat-bubble-body .msg-file-link{background:#fff9;border-color:#b8d9ef}.chat-bubble-body .msg-file-link:hover{background:#ebf5fb}.chat-bubble-body .msg-file-icon{font-size:18px;flex-shrink:0}.chat-bubble-body .msg-file-name{font-weight:500}.chat-bubble-body .msg-file-size{color:#9ca3af;font-size:11px;margin-left:auto}.chat-bubble-footer{display:flex;align-items:center;gap:8px;margin-top:4px}.chat-bubble-time{font-size:10px;color:#9ca3af;margin-left:auto}.chat-msg.pinned .chat-bubble{border-color:#f6e4a0;background:#fefce8}.chat-msg.own.pinned .chat-bubble{background:#fef9c3;border-color:#f6e4a0}@keyframes chat-flash{0%{background:#4a9fd82e}to{background:transparent}}.chat-msg--highlight{animation:chat-flash 1.5s ease-out;border-radius:10px}.chat-msg-actions{display:flex;flex-direction:column;gap:2px;opacity:0;transition:opacity .15s;margin-top:2px;flex-shrink:0}.chat-msg:hover .chat-msg-actions{opacity:1}.chat-action-btn{background:#fff;border:1px solid #E8EAED;border-radius:6px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;color:#6b7280;cursor:pointer;transition:background .1s,color .1s,border-color .1s;box-shadow:0 1px 3px #0000000f;padding:0}.chat-action-btn:hover{background:#f3f4f6;color:#374151}.chat-action-btn.active{color:#d97706;border-color:#f6e4a0;background:#fff9e6}.chat-action-btn.danger:hover{color:#ef4444;border-color:#fecaca;background:#fef2f2}.chat-edit-area{display:flex;flex-direction:column;gap:6px}.chat-edit-actions{display:flex;gap:6px;justify-content:flex-end}.chat-edit-save{padding:4px 12px;border-radius:6px;border:none;background:#4a9fd8;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.chat-edit-save:hover{background:#3a8fc8}.chat-edit-cancel{padding:4px 12px;border-radius:6px;border:1px solid #E8EAED;background:#fff;color:#374151;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.chat-edit-cancel:hover{background:#f3f4f6}.chat-edited-badge{font-size:10px;color:#9ca3af;font-style:italic;margin-right:2px}.chat-pin-badge{color:#d97706;flex-shrink:0}.chat-reply-btn{background:none;border:none;color:#9ca3af;cursor:pointer;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .1s,color .1s;flex-shrink:0;margin-top:4px}.chat-msg:hover .chat-reply-btn{opacity:1}.chat-reply-btn:hover{background:#f3f4f6;color:#4a9fd8}.chat-quote{display:flex;flex-direction:column;gap:1px;padding:4px 8px;margin-bottom:6px;border-left:3px solid #4A9FD8;border-radius:2px;background:#4a9fd814;cursor:pointer;font-size:12px;line-height:1.4}.chat-quote:hover{background:#4a9fd824}.chat-quote-author{font-weight:600;color:#4a9fd8}.chat-quote-text{color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.chat-bottom{flex-shrink:0;background:#fff}.chat-reply-bar{display:flex;align-items:center;padding:8px 24px;background:#ebf5fb;border-top:1px solid #B8D9EF;gap:10px}.chat-reply-bar-icon{color:#4a9fd8;flex-shrink:0}.chat-reply-bar-content{flex:1;min-width:0}.chat-reply-bar-text{font-size:13px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.chat-reply-bar-close{background:none;border:none;font-size:20px;color:#9ca3af;cursor:pointer;padding:0 4px;line-height:1}.chat-reply-bar-close:hover{color:#374151}.chat-input-area{padding:12px 24px 16px;border-top:1px solid #E8EAED}.chat-files-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#374151;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.chat-files-btn:hover{background:#f9fafb}.chat-files-btn.active{background:#ebf5fb;border-color:#4a9fd8;color:#4a9fd8}.chat-pinned-bar{display:flex;align-items:center;gap:8px;padding:6px 24px;background:#fff9e6;border-bottom:1px solid #F6E4A0;flex-shrink:0;cursor:pointer;transition:background .15s}.chat-pinned-bar:hover{background:#fff5cc}.chat-pinned-icon{color:#d97706;flex-shrink:0}.chat-pinned-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.chat-pinned-label{font-size:10px;font-weight:700;color:#d97706;text-transform:uppercase;letter-spacing:.04em}.chat-pinned-text{font-size:12px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-pinned-nav{display:flex;align-items:center;gap:4px;flex-shrink:0;font-size:11px;color:#9ca3af}.chat-pinned-nav button{background:none;border:none;padding:2px;cursor:pointer;color:#9ca3af;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.chat-pinned-nav button:hover{background:#0000000f;color:#374151}.chat-pinned-unpin{background:none;border:none;padding:4px;cursor:pointer;color:#9ca3af;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .1s,color .1s}.chat-pinned-unpin:hover{background:#0000000f;color:#374151}.chat-topics-bar{display:flex;align-items:center;gap:6px;padding:0 24px;height:40px;flex-shrink:0;background:#fff;border-bottom:1px solid #E8EAED;overflow-x:auto}.chat-topics-bar::-webkit-scrollbar{display:none}.chat-topic-chip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:12px;border:1px solid #E8EAED;background:#f7f8fa;color:#6b7280;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s}.chat-topic-chip:hover{background:#ebf5fb;border-color:#4a9fd8;color:#4a9fd8}.chat-topic-chip.active{background:#4a9fd8;border-color:#4a9fd8;color:#fff}.chat-new-topic-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;border:1px dashed #D1D5DB;background:transparent;color:#9ca3af;font-size:12px;cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s;flex-shrink:0}.chat-new-topic-btn:hover{border-color:#4a9fd8;color:#4a9fd8}.chat-topic-wrap{display:inline-flex;align-items:center;gap:2px;flex-shrink:0}.chat-topic-rename-btn{background:none;border:none;padding:2px 3px;cursor:pointer;color:#9ca3af;border-radius:4px;display:flex;align-items:center;opacity:0;transition:opacity .15s,color .1s,background .1s}.chat-topic-wrap:hover .chat-topic-rename-btn{opacity:1}.chat-topic-rename-btn:hover{color:#4a9fd8;background:#ebf5fb}.chat-topic-rename-input{border:1px solid #4A9FD8;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:500;color:#111827;outline:none;background:#fff;min-width:90px}.chat-topic-tag{display:inline-block;padding:1px 6px;border-radius:8px;background:#ebf5fb;color:#4a9fd8;font-size:10px;font-weight:600;margin-bottom:4px}.chat-selection-popup{position:fixed;z-index:9000;display:flex;align-items:center;gap:6px;background:#1f2937;color:#fff;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;box-shadow:0 4px 16px #0003;-webkit-user-select:none;user-select:none;pointer-events:all;transition:background .15s}.chat-selection-popup:hover{background:#111827}.chat-files-panel{width:240px;flex-shrink:0;background:#fff;border-left:1px solid #E8EAED;display:flex;flex-direction:column;overflow:hidden}.chat-files-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid #E8EAED;font-size:13px;font-weight:600;color:#374151;flex-shrink:0}.chat-files-head button{background:none;border:none;padding:2px;cursor:pointer;color:#9ca3af;border-radius:4px;display:flex;align-items:center;transition:color .1s,background .1s}.chat-files-head button:hover{color:#374151;background:#f3f4f6}.chat-files-empty{flex:1;display:flex;align-items:center;justify-content:center;font-size:12px;color:#9ca3af;padding:24px;text-align:center}.chat-files-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:8px;align-content:start}.chat-files-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:border-color .15s,opacity .15s}.chat-files-thumb:hover{border-color:#4a9fd8;opacity:.9}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:48px;text-align:center}.chat-empty-icon{font-size:40px;margin-bottom:12px}.chat-empty-title{font-size:16px;font-weight:600;color:#374151;margin-bottom:4px}.chat-empty-text{font-size:13px;color:#9ca3af}.dashboard-page{max-width:1100px;margin:0 auto}.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.dash-header h1{margin:0}.dash-add-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.dash-add-btn:hover{opacity:.9}.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media (max-width: 700px){.dash-grid{grid-template-columns:1fr}}.dash-widget{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e0e0e0);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.dash-widget.width-2{grid-column:span 2}@media (max-width: 700px){.dash-widget.width-2{grid-column:span 1}}.dash-widget-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--color-border, #e0e0e0);min-height:42px}.dash-widget-title{flex:1;font-size:14px;font-weight:600;border:none;background:transparent;color:inherit;outline:none;padding:0;font-family:inherit}.dash-widget-title:focus{border-bottom:1px solid var(--color-primary)}.dash-widget-actions{display:flex;gap:2px}.dash-widget-btn{background:none;border:none;cursor:pointer;padding:4px 6px;color:var(--color-text-subtle, #888);font-size:16px;line-height:1;border-radius:4px}.dash-widget-btn:hover{background:var(--color-bg, #f0f0f0);color:var(--color-text)}.dash-widget-body{padding:14px;flex:1;overflow:auto}.dash-kpi-big{text-align:center;padding:12px 0}.dash-kpi-big .kpi-value{font-size:40px;font-weight:700;color:var(--color-primary)}.dash-kpi-big .kpi-label{font-size:13px;color:var(--color-text-subtle);margin-top:4px}.dash-kpi-big .kpi-value.danger{color:var(--color-danger, #e53935)}.dash-status-bars{display:flex;flex-direction:column;gap:8px}.dash-status-row{display:flex;align-items:center;gap:10px}.dash-status-label{font-size:13px;min-width:90px;color:var(--color-text-subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-status-track{flex:1;height:18px;background:var(--color-bg, #f0f0f0);border-radius:9px;overflow:hidden}.dash-status-fill{height:100%;background:var(--color-primary);border-radius:9px;transition:width .3s;min-width:2px}.dash-status-count{font-size:13px;font-weight:600;min-width:28px;text-align:right}.dash-assignee-table{width:100%;border-collapse:collapse;font-size:13px}.dash-assignee-table th{text-align:left;font-weight:600;padding:4px 8px;border-bottom:1px solid var(--color-border, #e0e0e0);white-space:nowrap}.dash-assignee-table td{padding:4px 8px;border-bottom:1px solid var(--color-border, #e0e0e0)}.dash-recent-list{list-style:none;padding:0;margin:0}.dash-recent-item{padding:6px 0;border-bottom:1px solid var(--color-border, #e0e0e0);font-size:13px;display:flex;align-items:center;gap:8px}.dash-recent-item:last-child{border-bottom:none}.dash-recent-id{color:var(--color-text-subtle);font-size:12px;white-space:nowrap}.dash-recent-subject{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-recent-status{font-size:11px;padding:2px 6px;background:var(--color-bg, #f0f0f0);border-radius:4px;white-space:nowrap}.dash-worktime-summary{display:flex;gap:24px;margin-bottom:12px}.dash-worktime-stat{text-align:center}.dash-worktime-val{font-size:24px;font-weight:700;color:var(--color-primary)}.dash-worktime-lbl{font-size:12px;color:var(--color-text-subtle)}.dash-cfd-table{width:100%;border-collapse:collapse;font-size:12px}.dash-cfd-table th,.dash-cfd-table td{padding:3px 6px;border-bottom:1px solid var(--color-border, #e0e0e0);text-align:right}.dash-cfd-table th:first-child,.dash-cfd-table td:first-child{text-align:left}.dash-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:1000;display:flex;align-items:center;justify-content:center}.dash-picker-modal{background:var(--color-surface, #fff);border-radius:10px;padding:24px;width:460px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.dash-picker-modal h2{margin:0 0 16px;font-size:18px}.dash-picker-list{display:flex;flex-direction:column;gap:8px}.dash-picker-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--color-border, #e0e0e0);border-radius:8px;cursor:pointer;transition:border-color .15s}.dash-picker-item:hover{border-color:var(--color-primary);background:var(--color-bg, #f8f8f8)}.dash-picker-icon{font-size:22px;width:36px;text-align:center}.dash-picker-info{flex:1}.dash-picker-name{font-weight:600;font-size:14px}.dash-picker-desc{font-size:12px;color:var(--color-text-subtle);margin-top:2px}.dash-picker-close{margin-top:16px;width:100%;padding:8px;border:1px solid var(--color-border, #e0e0e0);background:transparent;border-radius:6px;cursor:pointer;font-size:14px}.dash-picker-close:hover{background:var(--color-bg, #f0f0f0)}.dash-widget-loading{text-align:center;padding:24px;color:var(--color-text-subtle);font-size:13px}.dash-empty{text-align:center;padding:60px 20px;color:var(--color-text-subtle)}.dash-empty p{margin:8px 0}.reports-page{max-width:1000px;margin:0 auto}.reports-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-bottom:20px}.report-type-btn{display:flex;flex-direction:column;gap:4px;padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.report-type-btn:hover{border-color:var(--color-primary)}.report-type-btn.active{border-color:var(--color-primary);background:var(--color-primary-light)}.report-type-label{font-size:14px;font-weight:600;color:var(--color-text)}.report-type-desc{font-size:12px;color:var(--color-text-subtle);line-height:1.3}.reports-toolbar{display:flex;align-items:flex-end;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filter-date{width:140px;padding:6px 8px;font-size:13px}.report-export-btn{margin-left:auto}.report-card{overflow-x:auto}.aging-days{font-weight:700;color:var(--color-danger)}.reports-tabs{display:flex;gap:4px;margin-bottom:20px}.reports-tab{padding:8px 16px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s}.reports-tab:hover{border-color:var(--color-primary)}.reports-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.worktime-statuses{font-size:14px;color:var(--color-text)}.passport-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.passport-body{flex:1;overflow-y:auto;padding:24px}.passport-header-card{display:flex;gap:20px;align-items:flex-start;padding:24px;margin-bottom:16px}.passport-logo-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;flex-shrink:0}.passport-header-info{flex:1;min-width:0}.passport-project-name{font-size:22px;font-weight:700;margin:0 0 2px}.passport-project-slug{font-size:13px;color:var(--color-text-subtle);font-family:monospace;margin-bottom:6px}.passport-project-desc-short{font-size:14px;color:var(--color-text);margin-bottom:8px}.passport-meta{font-size:12px;color:var(--color-text-subtle)}.passport-stats-mini{display:flex;gap:20px;flex-shrink:0}.passport-stat{text-align:center}.passport-stat-value{font-size:24px;font-weight:700;color:var(--color-primary);line-height:1.2}.passport-stat-label{font-size:11px;color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.5px}.passport-status-card{margin-bottom:16px;padding:20px 24px}.passport-status-card h3{margin:0 0 12px;font-size:15px}.passport-status-bars{display:flex;flex-direction:column;gap:8px}.passport-status-row{display:flex;align-items:center;gap:12px}.passport-status-label{width:140px;font-size:13px;display:flex;align-items:center;gap:6px;flex-shrink:0}.passport-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.passport-status-bar-wrap{flex:1;height:20px;background:var(--color-bg);border-radius:var(--radius);overflow:hidden}.passport-status-bar{height:100%;border-radius:var(--radius);transition:width .3s ease;opacity:.8}.passport-status-cnt{width:32px;text-align:right;font-size:13px;font-weight:600;flex-shrink:0}.passport-members-card{margin-bottom:16px;padding:20px 24px}.passport-members-card h3{margin:0 0 12px;font-size:15px}.passport-members-list{display:flex;flex-direction:column;gap:4px}.passport-member{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius);transition:background .15s}.passport-member:hover{background:var(--color-bg)}.passport-member-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.passport-member-info{flex:1;min-width:0;display:flex;flex-direction:column}.passport-member-name{font-weight:600;font-size:14px}.passport-member-login{font-size:12px;color:var(--color-text-subtle)}.passport-member-role{font-size:12px;color:var(--color-text-subtle);background:var(--color-bg);padding:2px 8px;border-radius:10px;flex-shrink:0}.passport-member-side{font-size:11px;padding:2px 8px;border-radius:10px;flex-shrink:0}.passport-member-side--executor{background:#0065ff1a;color:var(--color-primary)}.passport-member-side--customer{background:#e67e221a;color:#e67e22}.passport-desc-card{margin-bottom:16px;padding:20px 24px}.passport-desc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.passport-desc-header h3{margin:0;font-size:15px}.passport-desc-textarea{width:100%;min-height:140px;resize:vertical;font-size:14px;line-height:1.6}.passport-desc-body{font-size:14px;line-height:1.7;color:var(--color-text)}.passport-desc-body p{margin:0 0 6px}.passport-desc-empty{color:var(--color-text-subtle);font-style:italic}.passport-files-card{padding:20px 24px}.passport-drop-zone{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-subtle);font-size:14px;margin-bottom:16px;transition:border-color .2s,background .2s;cursor:default}.passport-drop-zone--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.passport-files-list{display:flex;flex-direction:column;gap:2px}.passport-file-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);transition:background .15s}.passport-file-row:hover{background:var(--color-bg)}.passport-file-icon{font-size:24px;flex-shrink:0;width:36px;text-align:center}.passport-file-info{flex:1;min-width:0}.passport-file-name{font-weight:600;font-size:14px;color:var(--color-primary);text-decoration:none;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.passport-file-name:hover{text-decoration:underline}.passport-file-desc{font-size:12px;color:var(--color-text);margin-top:2px}.passport-file-meta{font-size:11px;color:var(--color-text-subtle);margin-top:2px}.passport-files-empty{text-align:center;color:var(--color-text-subtle);padding:32px 16px;font-size:14px}.passport-stages-card{margin-bottom:16px;padding:20px 24px}.passport-stages-card h3{margin:0 0 16px;font-size:15px}.passport-stages-list{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.passport-stage-row{display:flex;align-items:center;gap:10px;padding:4px 0}.passport-stage-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.passport-stage-name{font-size:14px;font-weight:500;width:180px;min-width:0;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.passport-stage-dates{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.passport-stage-date-input{padding:3px 8px;font-size:13px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);width:136px}.passport-stage-date-input:disabled{opacity:.7;cursor:default}.passport-stage-date-sep{color:var(--color-text-subtle);font-size:13px;flex-shrink:0}.passport-stages-gantt-section{border-top:1px solid var(--color-border);padding-top:16px;margin-top:4px}.passport-stages-gantt-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-subtle);margin-bottom:10px}.passport-stages-gantt-wrap{width:100%;overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius)}.passport-stages-gantt{display:block;min-height:40px}.passport-stages-gantt-empty{color:var(--color-text-subtle);font-size:13px;font-style:italic;padding:8px 0}.btn-sm{padding:4px 12px;font-size:13px}.passport-upload-target{display:flex;align-items:center;gap:8px;margin-bottom:8px}.passport-upload-target-label{font-size:13px;color:var(--color-text-subtle);white-space:nowrap}.passport-upload-target-select{width:auto;min-width:160px;padding:3px 8px;font-size:13px}.passport-new-folder-row{display:flex;align-items:center;gap:6px;margin-bottom:12px}.passport-new-folder-input{width:220px;padding:4px 10px;font-size:13px}.passport-folder{border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:8px;overflow:hidden}.passport-folder-header{display:flex;align-items:center;justify-content:space-between;padding:0 10px 0 0;background:var(--color-bg);min-height:40px}.passport-folder-toggle{display:flex;align-items:center;gap:6px;flex:1;padding:8px 10px;background:none;border:none;cursor:pointer;color:var(--color-text);font-size:14px;text-align:left}.passport-folder-toggle:hover{background:var(--color-border);border-radius:var(--radius)}.passport-folder-icon{color:var(--color-primary);flex-shrink:0}.passport-folder-name{font-weight:600;flex:1}.passport-folder-rename-input{flex:1;padding:2px 6px;font-size:13px;font-weight:600;border:1px solid var(--color-primary);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text)}.passport-folder-count{font-size:11px;color:var(--color-text-subtle);background:var(--color-border);padding:1px 6px;border-radius:10px;flex-shrink:0}.passport-folder-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.passport-folder-action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:none;border-radius:var(--radius);cursor:pointer;color:var(--color-text-subtle);transition:background .15s,color .15s}.passport-folder-action-btn:hover{background:var(--color-border);color:var(--color-text)}.passport-folder-action-btn--danger:hover{background:#ef44441a;color:#ef4444}.passport-folder-files{padding:4px 0;border-top:1px solid var(--color-border)}.passport-folder-empty{padding:12px 20px;font-size:13px;color:var(--color-text-subtle);font-style:italic}.passport-file-folder-select{padding:2px 6px;font-size:12px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);max-width:130px;flex-shrink:0}.passport-root-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-subtle);padding:12px 0 4px}@media (max-width: 768px){.passport-header-card{flex-direction:column;align-items:center;text-align:center}.passport-stats-mini{margin-top:12px}.passport-status-label{width:100px}}.guide-page{display:flex;flex-direction:column;height:100%;background:#f0f2f5}.guide-page .page-topbar{display:flex;align-items:center;background:#fff;border-bottom:1px solid #E8EAED;padding:0 24px;height:56px;flex-shrink:0}.guide-page .page-topbar-left{display:flex;align-items:center;gap:8px}.guide-page .page-breadcrumb-project{font-size:14px;color:#888}.guide-page .page-breadcrumb-sep{color:#888}.guide-page .page-breadcrumb-current{font-size:14px;font-weight:600;color:#111827}.guide-layout{flex:1;display:flex;min-height:0;overflow:hidden}.guide-toc{width:220px;flex-shrink:0;background:#fff;border-right:1px solid #E8EAED;padding:16px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.guide-toc-title{font-size:11px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;padding:4px 12px 8px}.guide-toc-link{display:block;padding:6px 12px;border-radius:6px;font-size:12px;color:#666;cursor:pointer;transition:all .15s;text-decoration:none}.guide-toc-link:hover{background:#f9fafb;color:#374151}.guide-toc-link.active{background:#1a1a1a;color:#fff;font-weight:600}.guide-content{flex:1;overflow-y:auto;padding:32px 40px 60px;max-width:820px}.guide-h1{font-size:24px;font-weight:700;color:#1a1a1a;margin-bottom:4px}.guide-subtitle{font-size:14px;color:#9ca3af;margin-bottom:32px}.guide-section{margin-bottom:40px;scroll-margin-top:20px}.guide-section h2{font-size:20px;font-weight:700;color:#1a1a1a;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid #E8EAED}.guide-section h3{font-size:14px;font-weight:700;color:#374151;margin:16px 0 6px}.guide-section p{font-size:13px;line-height:1.7;color:#374151;margin-bottom:10px}.guide-section ul,.guide-section ol{font-size:13px;line-height:1.7;color:#374151;padding-left:20px;margin-bottom:10px}.guide-section li{margin-bottom:4px}.guide-section code{background:#f3f4f6;padding:1px 5px;border-radius:4px;font-size:12px;color:#1a1a1a}.guide-section kbd{display:inline-block;padding:2px 6px;border:1px solid #D1D5DB;border-radius:4px;background:#f9fafb;font-size:11px;font-weight:600;color:#374151;font-family:inherit;box-shadow:0 1px #d1d5db}.guide-tip{background:#ebf5fb;border:1px solid #B8D9EF;border-radius:8px;padding:10px 14px;font-size:12px;color:#1a6fa8;margin:12px 0;line-height:1.6}.guide-example{background:#f9fafb;border:1px solid #E8EAED;border-radius:8px;padding:12px 16px;font-size:12px;color:#374151;margin:12px 0;line-height:1.6}.guide-example strong{color:#1a1a1a}.guide-example ul,.guide-example ol{padding-left:16px;margin:6px 0 0}.guide-keys{display:flex;flex-direction:column;gap:8px}.guide-keys div{display:flex;align-items:center;gap:12px;font-size:13px;color:#374151}.guide-steps{counter-reset:step;list-style:none;padding-left:0}.guide-steps li{position:relative;padding-left:32px;margin-bottom:12px;font-size:13px;line-height:1.6;color:#374151}.guide-steps li:before{content:counter(step);counter-increment:step;position:absolute;left:0;top:1px;width:22px;height:22px;border-radius:11px;background:#1a1a1a;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.guide-layout{flex-direction:column}.guide-toc{width:100%;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid #E8EAED;padding:8px;gap:4px}.guide-toc-title{display:none}.guide-content{padding:20px}}.auto-content{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.auto-tabs{display:flex;gap:4px}.auto-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #E8EAED;border-radius:8px;background:#fff;color:#666;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.auto-tab:hover{background:#f9fafb;color:#374151}.auto-tab.active{background:#1a1a1a;border-color:#1a1a1a;color:#fff}.auto-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;font-size:14px;font-weight:700;color:#1a1a1a}.auto-add-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:11px;font-weight:600;cursor:pointer}.auto-add-btn:hover{background:#333}.auto-form{background:#fff;border:1px solid #E8EAED;border-radius:10px;padding:16px 20px;margin-bottom:12px;display:flex;flex-direction:column;gap:12px}.auto-form-field{display:flex;flex-direction:column;gap:4px}.auto-form-field label{font-size:11px;font-weight:600;color:#888}.auto-form-field input,.auto-form-field select{height:34px;padding:0 10px;font-size:13px;border:1px solid #E8EAED;border-radius:6px;background:#fff;color:#111827;outline:none;font-family:inherit}.auto-form-field input:focus,.auto-form-field select:focus{border-color:#4a9fd8;box-shadow:0 0 0 3px #4a9fd81f}.auto-form-field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.auto-form-row{display:flex;gap:12px}.auto-form-row .auto-form-field{flex:1}.auto-checks{display:flex;flex-wrap:wrap;gap:6px}.auto-check{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;border:1px solid #E8EAED;font-size:12px;color:#374151;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.auto-check:hover{background:#f9fafb}.auto-check.checked{background:#ebf5fb;border-color:#b8d9ef;color:#1a6fa8}.auto-check input{accent-color:#4A9FD8}.auto-save-btn{align-self:flex-start;height:34px;padding:0 20px;border:none;border-radius:6px;background:#1a1a1a;color:#fff;font-size:12px;font-weight:600;cursor:pointer}.auto-save-btn:disabled{opacity:.4;cursor:not-allowed}.auto-items{display:flex;flex-direction:column;gap:6px}.auto-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border:1px solid #E8EAED;border-radius:10px;transition:opacity .15s}.auto-item.inactive{opacity:.5}.auto-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.auto-item-url{font-family:monospace;font-size:12px;color:#111827;word-break:break-all}.auto-item-name{font-size:13px;font-weight:600;color:#1a1a1a}.auto-item-badges{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.auto-badge{padding:2px 8px;font-size:10px;font-weight:500;border-radius:8px}.auto-badge.blue{background:#ebf5fb;color:#4a9fd8}.auto-badge.amber{background:#fef3c7;color:#d97706}.auto-badge.green{background:#ecfdf5;color:#10b981}.auto-badge.red{background:#fef2f2;color:#ef4444}.auto-rule-arrow{color:#9ca3af;font-weight:700;font-size:12px}.auto-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.auto-toggle{border:none;background:none;cursor:pointer;padding:2px;display:flex}.auto-edit-btn{width:28px;height:28px;border:none;border-radius:6px;background:none;color:#d1d5db;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s}.auto-edit-btn:hover{background:#f3f4f6;color:#374151}.auto-empty{padding:32px;text-align:center;color:#9ca3af;font-size:13px;background:#fff;border:1px solid #E8EAED;border-radius:10px}.cal-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.cal-container{flex:1;overflow:auto;padding:20px 24px 24px;display:flex;flex-direction:column;min-height:0}.cal-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px}.cal-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text-subtle);cursor:pointer;transition:all .15s}.cal-nav-btn:hover{background:var(--color-bg);color:var(--color-text)}.cal-nav-title{display:flex;align-items:baseline;gap:8px;min-width:180px}.cal-month{font-size:18px;font-weight:700;color:var(--color-text)}.cal-year{font-size:15px;font-weight:400;color:var(--color-text-subtle)}.cal-today-btn{margin-left:4px;padding:5px 14px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text);font-size:13px;cursor:pointer;transition:all .15s}.cal-today-btn:hover{background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.cal-loading{font-size:13px;color:var(--color-text-subtle);margin-left:8px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;background:var(--color-border);gap:1px;flex:1;min-height:540px}.cal-weekday{background:var(--color-surface);padding:8px 0;text-align:center;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--color-text-subtle);text-transform:uppercase}.cal-cell{background:var(--color-surface);padding:6px 8px 8px;min-height:90px;cursor:pointer;transition:background .1s;display:flex;flex-direction:column;gap:3px;overflow:hidden}.cal-cell:hover{background:var(--color-bg)}.cal-cell--out{background:#fafafa;cursor:default}.cal-cell--out:hover{background:#fafafa}.cal-cell--today{background:#ebf5fb}.cal-cell--today:hover{background:#dbedfb}.cal-day-num{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.cal-day-num span{font-size:13px;font-weight:500;color:var(--color-text-subtle);line-height:1}.cal-cell--out .cal-day-num span{color:#c0c4cc}.cal-today-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--color-primary);color:#fff!important;border-radius:50%;font-size:12px!important;font-weight:700!important}.cal-add-btn{opacity:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:1px solid var(--color-border);border-radius:5px;background:var(--color-surface);color:var(--color-text-subtle);cursor:pointer;transition:all .12s;flex-shrink:0}.cal-cell:hover .cal-add-btn{opacity:1}.cal-add-btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.cal-events{display:flex;flex-direction:column;gap:2px;flex:1;overflow:hidden}.cal-event-chip{font-size:11px;font-weight:500;padding:2px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:opacity .1s;line-height:1.5}.cal-event-chip:hover{opacity:.8}.cal-task-chip{font-style:italic}.cal-more{font-size:11px;color:var(--color-text-subtle);padding-left:4px;font-weight:500}.cal-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000059;display:flex;align-items:center;justify-content:center}.cal-modal{background:var(--color-surface);border-radius:14px;width:420px;max-width:95vw;box-shadow:0 12px 40px #0000002e;display:flex;flex-direction:column;overflow:hidden}.cal-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;font-size:15px;font-weight:700;color:var(--color-text);border-bottom:1px solid var(--color-border)}.cal-modal-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:none;color:var(--color-text-subtle);cursor:pointer}.cal-modal-close:hover{background:var(--color-bg);color:var(--color-text)}.cal-modal-body{padding:18px 20px;display:flex;flex-direction:column;gap:14px}.cal-modal-foot{display:flex;align-items:center;gap:8px;padding:14px 20px;border-top:1px solid var(--color-border)}.cal-form-row{display:flex;flex-direction:column;gap:5px}.cal-form-row label{font-size:12px;font-weight:600;color:var(--color-text-subtle)}.cal-form-dates{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cal-form-error{font-size:12px;color:#ef4444;background:#fef2f2;padding:8px 12px;border-radius:8px}.cal-input{padding:8px 10px;border:1px solid var(--color-border);border-radius:8px;font-size:13px;color:var(--color-text);background:var(--color-bg);outline:none;width:100%;box-sizing:border-box;font-family:inherit}.cal-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4a9fd81f}.cal-textarea{resize:vertical}.cal-palette{display:flex;gap:8px;flex-wrap:wrap}.cal-color-btn{width:26px;height:26px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s}.cal-color-btn:hover{transform:scale(1.15)}.cal-color-btn.active{border-color:var(--color-text);transform:scale(1.1)}.cal-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s}.cal-btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.cal-btn-primary:hover{background:#3a8fc8}.cal-btn-primary:disabled{opacity:.6;cursor:default}.cal-btn-ghost{background:none;color:var(--color-text-subtle);border-color:var(--color-border)}.cal-btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.cal-btn-danger{background:none;color:#ef4444;border-color:#fecaca}.cal-btn-danger:hover{background:#fef2f2}.tmpl-page{display:flex;flex-direction:column;height:100%}.tmpl-content{flex:1;overflow-y:auto;padding:24px 32px;display:flex;flex-direction:column;gap:28px}.tmpl-portfolio-section{display:flex;flex-direction:column;gap:12px}.tmpl-portfolio-header{display:flex;align-items:center;gap:10px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.tmpl-portfolio-icon{display:inline-block;width:12px;height:12px;border-radius:3px;flex-shrink:0}.tmpl-portfolio-name{font-size:15px;font-weight:600;color:var(--color-text)}.tmpl-portfolio-count{font-size:12px;color:var(--color-text-subtle);margin-left:4px}.tmpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.tmpl-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;transition:box-shadow .15s}.tmpl-card:hover{box-shadow:0 2px 10px #00000012}.tmpl-card-head{display:flex;align-items:flex-start;gap:10px}.tmpl-card-icon{flex-shrink:0;width:32px;height:32px;background:var(--color-bg);border-radius:8px;display:flex;align-items:center;justify-content:center}.tmpl-card-info{flex:1;min-width:0}.tmpl-card-name{display:block;font-size:13px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tmpl-card-source{display:block;font-size:11px;color:var(--color-text-subtle);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tmpl-card-del{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;background:none;cursor:pointer;color:var(--color-text-subtle);border-radius:6px}.tmpl-card-del:hover{background:#fee2e2;color:#ef4444}.tmpl-card-desc{font-size:12px;color:var(--color-text-subtle);margin:0;line-height:1.5}.tmpl-card-meta{display:flex;gap:14px;padding-top:4px;border-top:1px solid var(--color-border)}.tmpl-card-meta-item{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--color-text-subtle)}.tmpl-empty{display:flex;align-items:center;gap:12px;padding:20px;background:var(--color-bg);border-radius:8px;color:var(--color-text-subtle);font-size:13px}.tmpl-empty-icon{color:var(--color-text-subtle);opacity:.4}.tmpl-empty-global{text-align:center;padding:48px 0;color:var(--color-text-subtle);font-size:14px}*{margin:0;padding:0;box-sizing:border-box;scrollbar-width:thin;scrollbar-color:transparent transparent}*:hover{scrollbar-color:rgba(128,128,128,.3) transparent}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:transparent;border-radius:3px}*:hover::-webkit-scrollbar-thumb{background:#8080804d}*::-webkit-scrollbar-thumb:hover{background:#80808080}:root{--color-primary: #4A9FD8;--color-primary-hover: #3A8FC8;--color-primary-light: #EBF5FB;--color-bg: #F0F2F5;--color-surface: #FFFFFF;--color-surface-2: #F9FAFB;--color-border: #E8EAED;--color-border-light: #F3F4F6;--color-text: #111827;--color-text-muted: #6B7280;--color-text-subtle: #9CA3AF;--color-text-inverse: #FFFFFF;--color-success: #10B981;--color-success-light: #ECFDF5;--color-danger: #EF4444;--color-danger-light: #FEF2F2;--color-warning: #F59E0B;--color-warning-light: #FFFBEB;--color-info: #4A9FD8;--color-badge-purple: #8B5CF6;--color-badge-teal: #14B8A6;--color-badge-green: #10B981;--color-column-bg: #FFFFFF;--shadow-card: 0 1px 4px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-overlay: 0 4px 16px rgba(0,0,0,.12), 0 1px 4px rgba(0,0,0,.06);--radius: 8px;--radius-lg: 12px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--input-border: #E8EAED;--input-focus: #4A9FD8;--input-bg: #FFFFFF;--color-estimate-empty-bg: #F0F2F5;--color-estimate-empty-text: #9CA3AF}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:1.5;font-size:14px}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:500;display:flex;align-items:center;justify-content:center;padding:16px}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0003;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-size:16px;font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:20px;color:var(--color-text-subtle);cursor:pointer;line-height:1;padding:2px 6px;border-radius:4px;transition:background .15s}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{padding:12px 20px;border-top:1px solid var(--color-border);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0}.modal-tab{padding:8px 16px;border:none;background:none;font-size:14px;font-weight:500;color:var(--color-text-subtle);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.modal-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.modal-tabs{display:flex;border-bottom:1px solid var(--color-border);padding:0 20px}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-subtle);background:var(--color-surface-2);border-bottom:2px solid var(--color-border)}.table td{padding:10px 12px;border-bottom:1px solid var(--color-border-light);color:var(--color-text)}.table tr:hover td{background:var(--color-bg)}@media (max-width: 768px){.topbar{flex-wrap:wrap;height:auto;padding:8px 12px;gap:8px}.topbar-left{flex-wrap:wrap;width:100%}.topbar-right{width:100%;justify-content:flex-end;flex-wrap:wrap}.nav{flex-wrap:wrap;gap:2px}.nav-link{padding:4px 8px;font-size:12px}.main-content{padding:12px}.kanban-board{justify-content:flex-start}.kanban-column{min-width:260px}.filter-bar{flex-direction:column;align-items:stretch}.filter-group,.filter-select{width:100%}.modal-content{max-width:95%;margin:0 8px}.modal-overlay{padding:20px 8px}.detail-grid{grid-template-columns:1fr}.estimate-row{flex-direction:column}.page-header h1{font-size:20px}.project-selector{max-width:120px;font-size:11px}.user-name,.user-role-badge,.version-btn{display:none}.create-task-grid{grid-template-columns:1fr}}@media (max-width: 480px){.topbar{padding:6px 8px}.logo-text{display:none}.nav-link{padding:4px 6px;font-size:11px}.kanban-column{min-width:240px}}
