:root{--font-sans: "Segoe UI Variable", "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;--font-mono: "SFMono-Regular", Consolas, "Liberation Mono", ui-monospace, monospace;color:#17212b;background:#eef3f5;font-family:var(--font-sans);font-size:15px;font-weight:400;line-height:1.5;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;font-family:var(--font-sans)}button,input,select,textarea{font:inherit;letter-spacing:0}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}input,select,textarea{width:100%;border:1px solid #c9d6dc;border-radius:6px;padding:10px 11px;color:#17212b;background:#fff;outline:0}input:focus,select:focus,textarea:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f}textarea{resize:vertical}.boot-screen{display:grid;min-height:100vh;place-items:center;align-content:center;gap:14px;color:#52616d}.brand-mark{display:inline-grid;width:48px;height:48px;place-items:center;border-radius:8px;overflow:hidden}.brand-mark.large{width:56px;height:56px}.brand-logo{width:100%;height:100%;object-fit:contain;border-radius:6px}.login-screen{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(430px,.92fr);min-height:100vh;background:linear-gradient(180deg,#ffffffb3,#eef6f8eb),#f5f8f9}.login-intro{position:relative;display:grid;align-content:space-between;gap:30px;overflow:hidden;padding:48px;color:#edf7f6;background:linear-gradient(140deg,#123945f5,#0f4a4ff0 58%,#0d5f58eb),#123945}.login-intro:before{position:absolute;top:18px;right:18px;bottom:18px;left:18px;border:1px solid rgb(255 255 255 / 9%);border-radius:8px;content:"";pointer-events:none}.login-intro:after{position:absolute;right:48px;bottom:46px;width:220px;height:160px;border:1px solid rgb(255 255 255 / 12%);border-radius:8px;background:#ffffff0d;content:"";pointer-events:none;transform:rotate(-5deg)}.login-brand,.sidebar-brand,.topbar-left,.topbar-actions,.panel-title,.security-strip,.user-chip,.login-points div,.input-with-icon,.table-meta,.heading-actions,.row-actions,.pagination{display:flex;align-items:center}.login-brand{position:relative;z-index:1;gap:14px}.login-brand .brand-mark{background:#fff;box-shadow:0 18px 42px #0000002e}.login-brand strong,.sidebar-brand strong{display:block;font-size:18px}.login-brand span,.sidebar-brand span{color:#ffffffbd;font-size:13px}.login-copy{position:relative;z-index:1;max-width:720px}.eyebrow{margin:0 0 7px;color:#0f766e;font-size:12px;font-weight:800;text-transform:uppercase}.login-intro .eyebrow{color:#a7f3d0}.login-copy h1{margin:0;max-width:780px;font-size:46px;line-height:1.05}.login-copy p:last-child{max-width:680px;color:#ffffffc7;line-height:1.65}.login-preview{position:relative;z-index:1;display:grid;gap:12px;max-width:680px;border:1px solid rgb(255 255 255 / 14%);border-radius:8px;padding:14px;background:#ffffff14;box-shadow:0 24px 70px #00000029}.login-preview-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;min-height:34px}.login-preview-header>span{width:10px;height:10px;border-radius:999px;background:#34d399;box-shadow:0 0 0 5px #34d39921}.login-preview-header strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-preview-header small{border-radius:999px;padding:5px 9px;color:#d7f8ef;background:#ffffff1a;font-weight:800}.login-preview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.login-preview-grid span{display:grid;gap:6px;min-height:104px;align-content:center;border:1px solid rgb(255 255 255 / 12%);border-radius:8px;padding:12px;background:#08232b42}.login-preview-grid svg{color:#99f6e4}.login-preview-grid b{color:#fff;font-size:22px;line-height:1}.login-preview-grid small{color:#ffffffad}.login-points{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.login-points div{gap:10px;min-height:54px;border:1px solid rgb(255 255 255 / 18%);border-radius:8px;padding:0 14px;background:#ffffff17;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-panel{display:grid;place-items:center;padding:42px}.login-form{position:relative;display:grid;gap:20px;width:min(460px,100%);border:1px solid #d7e5ea;border-radius:8px;padding:34px;background:#fff;box-shadow:0 28px 90px #17212b26}.login-form:before{position:absolute;top:0;right:0;bottom:0;left:0;height:5px;border-radius:8px 8px 0 0;background:linear-gradient(90deg,#0f766e,#17a2b8);content:""}.login-form-mark{display:inline-grid;width:54px;height:54px;place-items:center;border:1px solid #cfe2df;border-radius:8px;color:#0f766e;background:#eef9f7}.local-login-toggle{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border:1px solid transparent;border-radius:6px;color:#52616d;background:#f7fafb;font-weight:700}.local-login-toggle:hover{border-color:#d7e4e9;background:#fff}.local-login-toggle svg{transition:transform .16s ease}.local-login-toggle svg.open{transform:rotate(180deg)}.local-login-form{display:grid;gap:14px;border-top:1px solid #e5edf1;padding-top:18px}.form-heading h2,.page-heading h2{margin:0;line-height:1.15}.form-heading span,.page-heading span,.sync-summary p,.timeline-list small,.metric-card small,.user-chip small,.crumb{color:#687784}label span,.field-caption{display:block;margin-bottom:7px;color:#334250;font-size:13px;font-weight:700}label b{color:#ba1a1a}.input-with-icon{gap:9px;border:1px solid #c9d6dc;border-radius:6px;padding:0 10px;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.input-with-icon:focus-within{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f}.input-with-icon input{border:0;padding-inline:0;box-shadow:none}.primary-button,.secondary-button,.logout-button,.icon-button,.nav-item{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border-radius:6px;border:0;padding:0 14px;font-weight:700}.primary-button{color:#fff;background:#0f766e}.login-form .primary-button.full{min-height:44px;box-shadow:0 12px 26px #0f766e38}.login-form .primary-button.full:hover{background:#0c6861}.primary-button.full,.secondary-button.full{width:100%}.secondary-button{color:#263642;border:1px solid #cbd8df;background:#fff}.logout-button{color:#9c2626;border:1px solid #f0c9c9;background:#fff7f7}.icon-button{width:38px;padding:0;color:#334250;border:1px solid #cbd8df;background:#fff}.icon-button.danger{color:#ba1a1a}.form-error,.alert{margin:0;border:1px solid #ffd2cc;border-radius:6px;padding:12px 14px;color:#8b1d18;background:#fff2ef}.alert.inside{margin:14px 16px 0}.toast{margin:14px 16px 0;border:1px solid #bfe5d7;border-radius:6px;padding:11px 13px;color:#0d5f45;background:#effbf6}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{display:grid;grid-template-columns:292px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;overflow:auto;border-right:1px solid rgb(255 255 255 / 10%);background:linear-gradient(180deg,#ffffff14,#fff0 180px),#123945;padding:16px 14px 18px;scrollbar-color:rgb(255 255 255 / 22%) transparent}.sidebar-brand{gap:11px;min-height:62px;border:1px solid rgb(255 255 255 / 10%);border-radius:8px;padding:8px 10px;color:#fff;background:#ffffff12}.sidebar-brand .brand-mark{flex:0 0 auto;width:42px;height:42px;background:#fff}.sidebar-brand strong{font-size:16px;line-height:1.2}.nav-list{display:grid;gap:7px;margin-top:16px;padding-bottom:12px}.nav-section{display:grid;gap:5px;border-radius:8px;padding:6px;transition:background .15s ease,box-shadow .15s ease}.nav-section.active{background:#ffffff0f;box-shadow:inset 0 0 0 1px #ffffff14}.nav-section-title{display:flex;align-items:center;gap:9px;padding:0 6px;min-height:30px;color:#b8d0d6;font-size:12px;font-weight:800;text-transform:uppercase}.nav-section-title>span:nth-child(2){min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-section-title small{display:inline-grid;min-width:22px;height:22px;place-items:center;border-radius:999px;color:#dcecef;background:#ffffff17;font-size:11px}.nav-section-icon,.nav-item-icon{display:inline-grid;flex:0 0 auto;place-items:center}.nav-section-items{display:grid;gap:3px}.nav-item{justify-content:flex-start;width:100%;min-height:42px;color:#dcecef;background:transparent;padding:0 10px;text-align:left;transition:background .15s ease,color .15s ease,transform .15s ease}.nav-item span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item.child{min-height:38px;padding-left:10px;color:#c8dce1;font-size:14px;font-weight:650}.nav-item-icon{width:26px;height:26px;border-radius:6px;color:#a8c8cf;background:#ffffff0f}.nav-item:hover{color:#fff;background:#ffffff1a}.nav-item:hover .nav-item-icon{color:#fff;background:#ffffff1f}.nav-item.active{position:relative;color:#0f3f3b;background:#f5fbfa;box-shadow:0 10px 24px #081c2233}.nav-item.active:before{position:absolute;left:-6px;width:3px;height:22px;border-radius:999px;background:#24c6b8;content:""}.nav-item.active .nav-item-icon{color:#fff;background:#0f766e}.nav-item:focus-visible{outline:2px solid #8ee6dd;outline-offset:2px}.main-area{min-width:0;padding:18px 28px 34px}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:72px;margin:0 -10px 18px;border:1px solid #dbe6eb;border-radius:8px;padding:10px 12px 10px 14px;background:#ffffffeb;box-shadow:0 14px 38px #233b4714;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-left{gap:12px;min-width:0}.topbar-title-icon{display:inline-grid;flex:0 0 auto;width:44px;height:44px;place-items:center;border:1px solid #cfe2df;border-radius:8px;color:#0f766e;background:#eef9f7}.topbar-title{min-width:0}.topbar-title>span{display:block;margin-bottom:2px;color:#647887;font-size:12px;font-weight:800;text-transform:uppercase}.topbar h1{margin:0;overflow:hidden;color:#12202b;font-size:24px;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.topbar-title p{margin:4px 0 0;max-width:min(720px,48vw);overflow:hidden;color:#6b7c89;font-size:13px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.topbar-actions{flex:0 0 auto;gap:9px;min-width:0}.topbar .icon-button{width:42px;min-height:42px;border-color:#d4e2e7;background:#f8fbfc;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.topbar .icon-button:hover{border-color:#b8cbd3;background:#fff;box-shadow:0 8px 24px #233b4714}.global-search-wrap{position:relative}.global-search{display:flex;align-items:center;gap:9px;width:min(360px,30vw);height:42px;border:1px solid #d3e0e6;border-radius:6px;padding:0 12px;color:#657783;background:#f8fbfc;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.global-search:focus-within{border-color:#0f766e;background:#fff;box-shadow:0 0 0 3px #0f766e1c}.global-search input{border:0;padding:0;width:100%;outline:none;background:transparent}.global-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #cbd8df;border-radius:8px;box-shadow:0 8px 24px #0000001f;list-style:none;margin:0;padding:4px;z-index:1000;max-height:320px;overflow-y:auto}.global-search-item{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .12s}.global-search-item:hover,.global-search-item.active{background:#f0f6fa}.gsi-title{font-size:13.5px;font-weight:500;color:#17212b}.gsi-sub{font-size:12px;color:#6b8090;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-search-empty{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #cbd8df;border-radius:8px;box-shadow:0 8px 24px #0000001f;padding:12px 14px;font-size:13px;color:#6b8090;z-index:1000}.topbar .notif-bell{color:#334250}.topbar .notif-badge{top:-4px;right:-4px;border:2px solid white;background:#e04f3f}.user-chip{display:flex;align-items:center;gap:10px;min-height:42px;border:1px solid #d4e2e7;border-radius:6px;padding:0 11px 0 6px;color:#17212b;background:#f8fbfc;font-weight:700;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.user-chip:hover{border-color:#b8cbd3;background:#fff;box-shadow:0 8px 24px #233b4714}.user-avatar{display:inline-grid;width:34px;height:34px;place-items:center;border-radius:50%;color:#fff;background:linear-gradient(135deg,#0f766e,#17a2b8);font-weight:700;font-size:14px;overflow:hidden}.user-avatar.has-image{background:#eef3f5}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-chip span{display:block;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-icon{color:#ba1a1a;border:0;padding:0;width:auto;min-height:auto;background:transparent}.security-strip{gap:9px;min-height:38px;margin-bottom:18px;border:1px solid #cfe3df;border-radius:6px;padding:0 12px;color:#24574f;background:#edf8f5}.page-stack{display:grid;gap:16px}.page-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.page-heading h2{font-size:26px}.heading-actions{gap:10px}.resource-commandbar{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:42px}.resource-commandbar>span{color:#687784}.metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.metric-card,.work-panel,.table-panel,.sync-form,.sync-summary{border:1px solid #d7e1e6;border-radius:8px;background:#fff}.metric-card{display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;min-height:132px;padding:18px}.metric-icon{display:grid;width:44px;height:44px;place-items:center;border-radius:8px}.metric-card span,.metric-card small{display:block}.metric-card strong{display:block;margin:3px 0;font-size:34px;line-height:1.1}.tone-blue .metric-icon{color:#155e75;background:#e0f2fe}.tone-green .metric-icon{color:#166534;background:#dcfce7}.tone-amber .metric-icon{color:#92400e;background:#fef3c7}.tone-red .metric-icon{color:#9b241b;background:#fff1ef}.dashboard-page{gap:18px}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(360px,.7fr);gap:18px;border:1px solid #d7e1e6;border-radius:8px;padding:20px;background:linear-gradient(135deg,#fff,#f3fbf9)}.dashboard-hero h3{margin:12px 0 6px;font-size:24px}.dashboard-hero p{max-width:720px;margin:0;color:#536573}.health-pill{display:inline-flex;align-items:center;gap:7px;min-height:30px;border-radius:6px;padding:5px 10px;font-weight:700}.health-pill.tone-success{color:#17603a;background:#f0fbf4}.health-pill.tone-warning{color:#7a4c05;background:#fff8e8}.health-pill.tone-danger{color:#9b241b;background:#fff1ef}.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-content:stretch}.hero-stats span{display:grid;align-content:center;min-height:94px;border:1px solid #d8e3e8;border-radius:8px;padding:12px;color:#536573;background:#ffffffc2}.hero-stats strong{color:#12202b;font-size:30px;line-height:1}.dashboard-metrics{grid-template-columns:repeat(4,minmax(0,1fr))}.dashboard-layout{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;align-items:stretch}.dashboard-layout .dashboard-card{display:flex;min-width:0;min-height:100%;flex-direction:column}.dashboard-layout .span-4{grid-column:span 4}.dashboard-layout .span-6{grid-column:span 6}.dashboard-layout .data-bars,.dashboard-layout .watch-list,.dashboard-layout .timeline-list,.dashboard-layout .role-grid{flex:1}.completion-content{display:grid;grid-template-columns:auto minmax(0,1fr);gap:18px;align-items:center}.progress-ring{display:grid;width:118px;height:118px;place-items:center;border-radius:999px;background:radial-gradient(circle at center,white 0 58%,transparent 59%),conic-gradient(#0f766e var(--value),#e5edf1 0)}.progress-ring span{font-size:24px;font-weight:800}.status-stack,.mini-kpis{display:grid;gap:8px}.status-stack span,.mini-kpis span{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:34px;border:1px solid #e2eaee;border-radius:6px;padding:7px 10px;color:#536573;background:#f8fbfc}.status-stack strong,.mini-kpis strong{color:#12202b;font-size:18px}.mini-kpis{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:14px}.mini-kpis span{display:grid;justify-items:start;align-content:center;min-height:58px}.data-bars{display:grid;gap:10px}.data-bar-row{display:grid;grid-template-columns:minmax(110px,.8fr) minmax(90px,1fr) auto;gap:10px;align-items:center}.data-bar-row span{overflow:hidden;color:#455766;text-overflow:ellipsis;white-space:nowrap}.data-bar-row strong{min-width:24px;text-align:right}.data-bar-track{height:9px;overflow:hidden;border-radius:999px;background:#edf3f5}.data-bar-track i{display:block;height:100%;border-radius:inherit}.data-bar-track i.tone-blue{background:#0891b2}.data-bar-track i.tone-green{background:#16a34a}.data-bar-track i.tone-amber{background:#d98a00}.watch-list{display:grid;gap:10px}.watch-list article{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;border:1px solid #e2eaee;border-radius:6px;padding:10px;background:#f8fbfc}.watch-list strong,.watch-list small{display:block}.watch-list strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.watch-list small,.dashboard-empty{color:#687784}.watch-list article>span{border-radius:6px;padding:5px 8px;color:#24574f;background:#edf8f5;font-weight:700;white-space:nowrap}.dashboard-empty{margin:0}.workbench-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(300px,.65fr);gap:14px}.work-panel{padding:18px}.panel-title{gap:9px;margin-bottom:14px}.panel-title h3{margin:0;font-size:17px}.timeline-list{display:grid;gap:14px}.timeline-list div{display:grid;grid-template-columns:auto minmax(0,1fr);gap:2px 10px}.timeline-list small{grid-column:2}.dot{width:10px;height:10px;margin-top:5px;border-radius:999px}.dot.success{background:#16a34a}.dot.warning{background:#f59e0b}.dot.danger{background:#dc2626}.role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.role-grid span{min-height:36px;border:1px solid #d8e3e8;border-radius:6px;padding:9px 10px;background:#f8fbfc;font-weight:700}.table-panel{overflow:hidden}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #e5edf1}.toolbar-filters{display:flex;align-items:center;flex:1;gap:10px;min-width:0}.search-box{display:flex;align-items:center;gap:9px;width:min(520px,100%);height:40px;border:1px solid #cbd8df;border-radius:6px;padding:0 11px;background:#fff}.search-box input{border:0;padding:0}.filter-select{width:min(240px,100%);height:40px;border:1px solid #cbd8df;border-radius:6px;background:#fff;color:#263743;padding:0 11px}.table-meta{gap:8px;color:#536573;white-space:nowrap}.data-table-wrap{overflow:auto}.data-table{width:100%;min-width:940px;border-collapse:collapse}.data-table th,.data-table td{height:52px;padding:10px 14px;border-bottom:1px solid #edf2f5;text-align:left;vertical-align:middle}.data-table th{color:#5b6b78;background:#f7fafb;font-size:13px;font-weight:800}.cell-text{display:inline-block;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:pre-line}.nhom-co-quan-table{min-width:1040px}.nhom-co-quan-table th:nth-child(2),.nhom-co-quan-table td:nth-child(2){width:68%}.nhom-co-quan-units{max-width:none;white-space:normal;line-height:1.55}.link-button{border:0;background:transparent;color:#2078b4;font:inherit;font-weight:800;text-align:left;cursor:pointer}.nhom-co-quan-editor{display:grid;gap:20px;border-color:#c8dde7;box-shadow:0 12px 28px #0a3b4e14;padding:18px}.editor-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:4px}.editor-head>div{display:grid;gap:4px}.editor-head span{color:#667785;font-size:13px}.nhom-co-quan-form-row{display:grid;grid-template-columns:minmax(280px,1.4fr) minmax(260px,1fr) 140px;gap:16px;align-items:end}.nhom-co-quan-form-row label{display:grid;gap:8px;min-width:0}.nhom-co-quan-form-row label span{color:#344654;font-size:13px;font-weight:800}.nhom-co-quan-form-row input,.nhom-co-quan-form-row select{width:100%;min-height:42px}.picklist-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}.picklist-pane{min-height:260px;border:1px solid #dce5ea;background:#fff;overflow:hidden;border-radius:6px}.picklist-title{padding:9px 14px;background:#09699a;color:#fff;font-weight:900;text-align:center;text-transform:uppercase}.picklist-controls{display:grid;grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) auto auto;gap:10px;padding:12px;border-bottom:1px solid #edf2f5}.picklist-options,.selected-list{display:grid;align-content:start;max-height:260px;overflow:auto;padding:8px 12px 12px}.picklist-options button{border:0;border-radius:0;background:transparent;color:#26333c;padding:9px 10px;text-align:left;cursor:pointer}.picklist-options button:hover{background:#eaf4fb}.selected-list>div{display:flex;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid #f1f5f7;padding:8px 4px 8px 8px}.nhom-co-quan-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:2px}.nhom-co-quan-actions .primary-button,.nhom-co-quan-actions .secondary-button{min-width:92px;min-height:42px;padding:0 18px}.danger-button{justify-self:center;margin-top:12px;border:0;border-radius:6px;background:#d92d20;color:#fff;padding:9px 18px;font-weight:900;cursor:pointer}@media(max-width:980px){.nhom-co-quan-form-row,.picklist-grid,.picklist-controls{grid-template-columns:1fr}}.status-badge{display:inline-flex;align-items:center;min-height:26px;border-radius:999px;padding:0 10px;font-size:13px;font-weight:800;white-space:nowrap}.status-badge.success{color:#166534;background:#dcfce7}.status-badge.warning{color:#92400e;background:#fef3c7}.status-badge.danger{color:#991b1b;background:#fee2e2}.status-badge.neutral{color:#455766;background:#eef3f5}.status-badge.info{color:#1d4ed8;background:#dbeafe}.progress-cell{display:grid;grid-template-columns:46px minmax(90px,1fr);align-items:center;gap:8px;max-width:180px}.progress-cell div{height:8px;overflow:hidden;border-radius:999px;background:#e1e9ee}.progress-cell i{display:block;height:100%;border-radius:inherit;background:#0f766e}.actions-col{width:112px}.row-actions{gap:6px}.empty-table{height:150px;color:#687784;text-align:center}.pagination{justify-content:space-between;gap:8px;padding:14px 16px;border-top:1px solid #edf2f5;flex-wrap:wrap}.pagination-summary{min-height:34px;display:inline-flex;align-items:center;color:#536573;font-size:13px;font-weight:700;white-space:nowrap}.pagination-controls,.pagination-pages{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}.pagination button{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;border:1px solid #cbd8df;border-radius:6px;padding:0 10px;color:#263642;background:#fff;font-weight:700}.pagination button:hover:not(:disabled){border-color:#0f766e;color:#0f766e;background:#eef9f7}.pagination button.active{border-color:#0f766e;color:#fff;background:#0f766e;box-shadow:0 6px 16px #0f766e2e}.pagination-size{width:auto;min-width:104px;height:34px;border:1px solid #cbd8df;border-radius:6px;padding:0 8px;background:#fff;font-size:13px;font-weight:700}.pagination-ellipsis{min-width:24px;color:#6a7a86;font-weight:800;text-align:center}.pagination-info{min-height:34px;display:inline-flex;align-items:center;margin-left:6px;color:#536573;font-weight:600}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:20px;background:#101c246b}.modal{width:min(920px,100%);max-height:calc(100vh - 40px);overflow:auto;border-radius:8px;background:#fff;box-shadow:0 24px 80px #17212b47}.modal header,.modal footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px}.modal header{border-bottom:1px solid #e5edf1}.modal footer{justify-content:flex-end;border-top:1px solid #e5edf1}.modal h2{margin:0;font-size:20px}.modal-body{padding:18px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.wide{grid-column:1 / -1}.switch-control{display:inline-flex;width:48px;height:28px;align-items:center;margin-top:4px}.switch-control input{position:absolute;opacity:0;pointer-events:none}.switch-control i{position:relative;width:48px;height:28px;border-radius:999px;background:#cbd8df;transition:.16s ease}.switch-control i:after{position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:999px;background:#fff;content:"";transition:.16s ease}.switch-control input:checked+i{background:#0f766e}.switch-control input:checked+i:after{transform:translate(20px)}.sync-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:14px}.sync-form,.sync-summary{padding:18px}.sync-form{display:grid;gap:14px}.upload-panel{display:grid;gap:12px;border:1px dashed #9fc9c3;border-radius:8px;padding:14px;background:#f4fbf9}.upload-panel strong,.upload-panel span{display:block}.upload-panel span{color:#5f707d;font-size:13px}.hr-sync-panel,.manual-sync-panel{display:grid;gap:14px}.sync-table-wrap{overflow:auto;border:1px solid #dbe5ea;border-radius:8px}.sync-table{min-width:720px}.sync-table td[colspan]{color:#71808c;text-align:center}.upload-actions{display:flex;flex-wrap:wrap;gap:10px}.file-picker{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border:1px solid #0f766e;border-radius:6px;padding:0 14px;color:#0f766e;background:#fff;font-weight:800;cursor:pointer}.file-picker span{margin:0;color:inherit;font-size:14px}.file-picker input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.segmented-control{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.segmented-control button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border:1px solid #cbd8df;border-radius:6px;color:#334250;background:#fff;font-weight:700}.segmented-control button.active{color:#fff;border-color:#0f766e;background:#0f766e}.sync-summary{align-self:start}.sync-result{display:grid;gap:9px}.sync-result svg{color:#16a34a}.sync-result code{display:block;overflow:auto;border-radius:6px;padding:9px;color:#455766;background:#f1f5f7}.sync-errors{display:grid;gap:6px;border-radius:6px;padding:10px;color:#8b1d18;background:#fff2ef}.doc-ai-grid{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}.doc-input-panel,.doc-review-panel{display:grid;gap:14px;padding:12px}.doc-input-panel{max-width:100%}.panel-heading-line,.draft-toolbar,.assignment-head,.publish-bar{display:flex;align-items:center;justify-content:space-between;gap:10px}.panel-heading-line{justify-content:flex-start;color:#263642}.upload-drop{position:relative;display:grid;place-items:center;gap:9px;min-height:80px;border:2px dashed #8bbdb7;border-radius:8px;color:#0f766e;background:#f3fbf9;text-align:center;cursor:pointer;transition:all .2s ease}.upload-drop:hover{border-color:#0f766e;background:#eef9f7;box-shadow:0 2px 8px #0f766e1a}.upload-drop svg{flex-shrink:0;color:#0f766e;transition:transform .2s ease}.upload-drop:hover svg{transform:scale(1.1)}.upload-drop span{margin:0;color:#24574f;font-weight:500}.upload-drop input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.upload-drop[data-has-file=true] input{pointer-events:none}.upload-drop[data-has-file=true]{border-style:solid;border-color:#0f766e;background:#eef9f7;grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:start;gap:12px}.upload-drop[data-has-file=true] svg{grid-column:1;grid-row:1;justify-self:center;width:32px;height:32px}.upload-drop[data-has-file=true] .file-info{grid-column:1;grid-row:2;justify-self:center}.upload-drop[data-has-file=true] .clear-file-btn{grid-column:2;grid-row:1}.file-info{display:flex;flex-direction:column;gap:2px;text-align:left;min-width:0}.file-name{color:#0f766e;font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#536573;font-size:12px}.clear-file-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:4px;background:transparent;color:#536573;cursor:pointer;transition:all .15s ease;flex-shrink:0}.clear-file-btn:hover{background:#0f766e1a;color:#0f766e}.empty-draft{display:grid;min-height:280px;place-items:center;align-content:center;gap:10px;color:#687784;text-align:center}.warning-list{display:grid;gap:8px}.warning-list span{border:1px solid #f5d99a;border-radius:6px;padding:9px 10px;color:#7a4c05;background:#fff8e8}.assignment-list{display:grid;gap:12px}.assignment-item{display:grid;gap:12px;border:1px solid #dce6eb;border-radius:8px;padding:14px;background:#fbfdfe}.assignment-item small{color:#687784}.suggestion-item[data-selected=false]{opacity:.72;background:#f6f8fa}.suggestion-item[data-priority=high]{border-left:4px solid #d92d20;background:snow}.suggestion-item[data-priority=medium]{border-left:4px solid #d98a00;background:#fffdf7}.suggestion-item[data-priority=low]{border-left:4px solid #24965c;background:#fbfffc}.suggestion-check{display:inline-flex;align-items:center;gap:8px;color:#263642;font-weight:700}.suggestion-check input{width:16px;height:16px;margin:0;accent-color:#0f766e}.suggestion-item .priority-badge{display:inline-flex;align-items:center;min-height:28px;border-radius:6px;padding:4px 10px;font-size:13px;font-weight:700;margin-left:auto}.suggestion-item .priority-badge[data-priority=high]{border:1px solid #ffc4bd;color:#9b241b;background:#fff1ef}.suggestion-item .priority-badge[data-priority=medium]{border:1px solid #f5d99a;color:#7a4c05;background:#fff8e8}.suggestion-item .priority-badge[data-priority=low]{border:1px solid #b8d7c3;color:#17603a;background:#f0fbf4}.suggestion-summary,.suggestion-tags{display:flex;flex-wrap:wrap;gap:8px}.suggestion-summary span,.suggestion-tags span{display:inline-flex;align-items:center;min-height:28px;border:1px solid #dce6eb;border-radius:6px;padding:4px 9px;color:#455766;background:#f7fafb;font-size:13px}.suggestion-summary span[data-priority=high]{border-color:#ffc4bd;color:#9b241b;background:#fff1ef}.suggestion-summary span[data-priority=medium]{border-color:#f5d99a;color:#7a4c05;background:#fff8e8}.suggestion-summary span[data-priority=low]{border-color:#b8d7c3;color:#17603a;background:#f0fbf4}.suggestion-tags span{color:#0f766e;background:#eef9f7;border-color:#b8d7d2}.form-grid.compact{gap:12px}.publish-bar{position:sticky;bottom:0;border-top:1px solid #e5edf1;padding-top:14px;background:#fff}.publish-bar span{color:#536573}.mobile-only,.scrim{display:none}@media(max-width:1120px){.topbar{align-items:stretch;flex-direction:column}.topbar-actions,.global-search{width:100%}.topbar-title p{max-width:100%}.metric-grid,.workbench-grid,.sync-layout,.doc-ai-grid,.dashboard-hero,.dashboard-metrics,.dashboard-layout,.report-hero,.report-filter-bar,.report-metric-grid,.report-grid{grid-template-columns:1fr}.dashboard-layout .work-panel,.dashboard-layout .task-watch-panel,.dashboard-layout .alert-panel,.dashboard-layout .span-4,.dashboard-layout .span-6,.completion-panel,.report-card.span-8,.report-card.span-4{grid-column:auto}.hero-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:860px){.login-screen,.app-shell{grid-template-columns:1fr}.login-intro{padding:28px}.login-copy h1{font-size:30px}.login-points,.hero-stats,.mini-kpis,.completion-content,.report-hero{grid-template-columns:1fr}.report-tabs{display:grid;width:100%;grid-template-columns:1fr}.data-bar-row{grid-template-columns:1fr auto}.data-bar-track{grid-column:1 / -1}.sidebar{position:fixed;z-index:60;width:min(320px,86vw);transform:translate(-100%);transition:transform .16s ease}.sidebar.is-open{transform:translate(0)}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;display:block;border:0;background:#101c246b}.mobile-only{display:inline-flex}.sidebar-brand .mobile-only{margin-left:auto}.main-area{padding:14px}.topbar{margin-inline:0}.topbar-left{align-items:flex-start}.page-heading,.table-toolbar,.topbar-actions,.toolbar-filters{align-items:stretch;flex-direction:column}.filter-select{width:100%}.heading-actions{flex-wrap:wrap}.form-grid,.segmented-control{grid-template-columns:1fr}}@media(max-width:560px){.login-panel{padding:18px}.login-form{padding:20px}.user-chip,.global-search,.security-strip{display:none}.topbar{min-height:auto;padding:10px}.topbar-title-icon{width:40px;height:40px}.topbar h1{font-size:20px}.topbar-title p{display:none}.pagination{justify-content:space-between}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.task-management-page{gap:18px}.task-board-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,240px);gap:18px;align-items:center;border:1px solid #d7e1e6;border-radius:8px;padding:18px;background:linear-gradient(135deg,#fff,#f3fbf9)}.task-board-hero h3{margin:10px 0 5px;font-size:24px}.task-board-hero p{max-width:760px;margin:0;color:#536573}.task-hero-score{display:grid;min-height:122px;align-content:center;justify-items:center;border:1px solid #cfe3df;border-radius:8px;background:#fff}.task-hero-score span,.task-hero-score small{color:#687784;font-weight:700}.task-hero-score strong{color:#0f766e;font-size:38px;line-height:1}.task-metric-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.task-metric{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;min-height:104px;border:1px solid #d7e1e6;border-radius:8px;padding:15px;background:#fff}.task-metric-icon{display:grid;width:42px;height:42px;place-items:center;border-radius:8px}.task-metric span,.task-metric small{display:block}.task-metric span{color:#52616d;font-weight:700}.task-metric strong{display:block;margin:2px 0;font-size:30px;line-height:1.1}.task-metric small{color:#687784}.task-metric.tone-blue .task-metric-icon{color:#155e75;background:#e0f2fe}.task-metric.tone-red .task-metric-icon{color:#9b241b;background:#fff1ef}.task-metric.tone-amber .task-metric-icon{color:#92400e;background:#fef3c7}.task-metric.tone-cyan .task-metric-icon{color:#0f766e;background:#ccfbf1}.task-metric.tone-green .task-metric-icon{color:#166534;background:#dcfce7}.cv-filter-panel{border:1px solid #d7e1e6;border-radius:8px;padding:14px;background:#fff}.cv-filter-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.cv-filter-head>div{display:inline-flex;align-items:center;gap:8px}.cv-filter-head span{color:#687784;font-weight:700}.cv-filter-bar{display:grid;grid-template-columns:minmax(260px,1.6fr) repeat(5,minmax(130px,1fr)) auto;gap:10px;align-items:center}.cv-filter-bar input,.cv-filter-bar select{width:100%;min-width:0;min-height:38px;padding:8px 10px;font-size:13px}.cv-search-input{display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;align-items:center;min-height:38px;border:1px solid #c9d6dc;border-radius:6px;padding:0 10px;background:#fff}.cv-search-input input{border:0;padding-inline:0;box-shadow:none}.cv-filter-bar .secondary-button{white-space:nowrap}.view-toggle{display:flex;gap:2px;border:1px solid #c9d6dc;border-radius:6px;overflow:hidden}.view-toggle button{padding:6px 12px;border:none;background:#fff;color:#52616d;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:5px}.view-toggle button.active{background:#0f766e;color:#fff}.task-table-panel{overflow:hidden}.task-table{min-width:1120px}.task-table-head{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid #e2eaee;padding:14px 16px}.task-table-head strong,.task-table-head span{display:block}.task-table-head strong{font-size:18px}.task-table-head span,.task-table-tools{color:#687784;font-weight:700}.task-table-tools{min-height:32px;display:inline-flex;align-items:center;border-radius:6px;padding:0 10px;color:#24574f;background:#edf8f5}.cv-table-wrap{overflow-x:auto}.cv-table{width:100%;border-collapse:collapse;font-size:13.5px}.cv-table th{padding:12px 14px;text-align:left;font-weight:800;color:#52616d;background:#f5f8f9;border-bottom:1px solid #e2e8f0;white-space:nowrap}.cv-table td{padding:12px 14px;border-bottom:1px solid #f0f4f6;vertical-align:middle}.cv-table tbody tr:hover{background:#f8fbfc}.task-table tr.deadline-overdue,.task-table tr.deadline-today,.task-table tr.deadline-soon,.task-table tr.deadline-ok,.task-table tr.deadline-done{color:inherit}.task-table tr.deadline-overdue td:not(.cv-deadline-cell),.task-table tr.deadline-today td:not(.cv-deadline-cell),.task-table tr.deadline-soon td:not(.cv-deadline-cell),.task-table tr.deadline-ok td:not(.cv-deadline-cell),.task-table tr.deadline-done td:not(.cv-deadline-cell){color:inherit}.task-table td.cv-code{color:#52616d}.task-table td.cv-unit-cell{color:#24574f}.cv-code{font-family:var(--font-mono);font-size:12px;color:#52616d;white-space:nowrap}.cv-title,.cv-title-cell strong{font-weight:800;color:#17212b}.cv-title{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cv-title-cell{min-width:280px;max-width:460px}.cv-title-cell strong,.cv-title-cell span{display:block}.cv-title-cell strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cv-title-cell span{margin-top:3px;color:#687784;font-size:12px}.cv-row{cursor:pointer}.cv-actions{display:flex;gap:4px;justify-content:flex-end;min-width:126px}.cv-progress-bar{height:8px;min-width:80px;background:#e2e8f0;border-radius:4px;overflow:hidden}.cv-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.cv-progress-label{font-size:11px;font-weight:600;color:#475569;text-align:center;display:block;line-height:1}.cv-progress-cell{display:flex;flex-direction:column;gap:3px;min-width:90px}.cv-deadline-cell strong,.cv-deadline-cell small{display:block}.cv-deadline-cell strong{white-space:nowrap}.cv-deadline-cell small{margin-top:3px;font-size:12px;font-weight:800}.cv-deadline-cell.deadline-overdue,.cv-deadline-cell.deadline-overdue small{color:#dc2626}.cv-deadline-cell.deadline-today,.cv-deadline-cell.deadline-today small,.cv-deadline-cell.deadline-soon,.cv-deadline-cell.deadline-soon small{color:#d97706}.cv-deadline-cell.deadline-ok,.cv-deadline-cell.deadline-ok small,.cv-deadline-cell.deadline-done,.cv-deadline-cell.deadline-done small{color:#16a34a}.cv-unit-cell{max-width:260px;overflow:hidden;color:#24574f;text-overflow:ellipsis;white-space:nowrap}.priority-badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;border-radius:4px;padding:0 9px;font-size:11px;font-weight:800;line-height:1;white-space:nowrap;background:#f1f5f9;color:#475569;vertical-align:middle}.priority-badge.priority-urgent,.priority-badge.khan-cap{background:#fef2f2;color:#dc2626}.priority-badge.priority-high,.priority-badge.cao{background:#fff7ed;color:#d97706}.priority-badge.priority-medium,.priority-badge.trung-binh{background:#eff6ff;color:#2563eb}.priority-badge.priority-low,.priority-badge.thap{background:#f0fdf4;color:#16a34a}.status-badge.status-MOI,.status-badge.status-MOI_TAO{color:#475569;background:#f1f5f9}.status-badge.status-DA_PHAN_CONG{color:#0369a1;background:#e0f2fe}.status-badge.status-DANG_XU_LY{color:#1d4ed8;background:#dbeafe}.status-badge.status-CHO_PHAN_HOI{color:#a16207;background:#fef3c7}.status-badge.status-CHO_DUYET{color:#92400e;background:#fef3c7}.status-badge.status-HOAN_THANH{color:#166534;background:#dcfce7}.status-badge.status-TAM_DUNG{color:#455766;background:#eef3f5}.status-badge.status-QUA_HAN,.status-badge.status-TRE_HAN{color:#991b1b;background:#fee2e2}.status-badge.status-HUY,.status-badge.status-HUY_BO{color:#6b7280;background:#f3f4f6}.deadline-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}.badge-overdue{background:#fef2f2;color:#dc2626}.badge-today{background:#fff7ed;color:#d97706}.badge-soon{background:#fefce8;color:#a16207}.badge-ok,.badge-done{background:#f0fdf4;color:#16a34a}.badge-hours{background:#eff6ff;color:#2563eb}.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;align-items:flex-start}.kanban-col{flex:0 0 260px;min-width:220px;background:#f5f8f9;border-radius:10px;display:flex;flex-direction:column}.kanban-col-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 8px;border-bottom:2px solid #e2e8f0;font-weight:600;font-size:13px;color:#17212b}.kanban-count{background:#e2e8f0;color:#52616d;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700}.kanban-cards{display:flex;flex-direction:column;gap:8px;padding:10px;min-height:60px}.kanban-card{background:#fff;border-radius:8px;border:1px solid #e2e8f0;padding:10px 12px;cursor:pointer;transition:box-shadow .15s,border-color .15s}.kanban-card:hover{box-shadow:0 2px 8px #0f766e1f;border-color:#0f766e40}.kanban-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:6px;margin-bottom:5px}.kanban-card-code{font-family:var(--font-mono);font-size:11px;color:#94a3b8}.kanban-card-title{font-weight:500;font-size:13px;color:#17212b;line-height:1.35;margin-bottom:6px}.kanban-card-meta{display:flex;flex-wrap:wrap;gap:5px;align-items:center;font-size:11.5px;color:#52616d}.kanban-card-actions{display:flex;gap:3px;margin-top:6px;justify-content:flex-end}.modal-panel{background:#fff;border-radius:12px;box-shadow:0 8px 40px #0000002e;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:min(900px,95vw)}.modal-panel.wide{width:min(1100px,96vw)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid #e2e8f0;gap:12px}.modal-header-actions{display:flex;gap:6px;flex-shrink:0}.modal-title{font-size:17px;font-weight:700;color:#17212b;line-height:1.3}.modal-code{font-family:var(--font-mono);font-size:12px;color:#94a3b8;margin-top:2px}.modal-tabs{display:flex;gap:0;border-bottom:1px solid #e2e8f0;padding:0 20px;margin-top:8px}.tab-btn{padding:9px 16px;border:none;background:transparent;color:#52616d;font-size:13.5px;font-weight:500;border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}.tab-btn.active{color:#0f766e;border-bottom-color:#0f766e}.tab-btn:hover:not(.active){color:#17212b}.modal-footer{padding:14px 20px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:8px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}.detail-row{display:flex;flex-direction:column;gap:3px}.detail-row.wide,.detail-grid .wide{grid-column:1 / -1}tr.deadline-overdue td,.deadline-overdue{color:#dc2626}tr.deadline-today td:last-of-type,.deadline-today{color:#d97706}tr.deadline-soon td:last-of-type,.deadline-soon{color:#ca8a04}tr.deadline-ok,.deadline-ok,tr.deadline-done,.deadline-done{color:#16a34a}.detail-row>span:first-child,.detail-row label{font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:0}.detail-row span{font-size:14px;color:#17212b}.detail-progress{margin-top:12px}.detail-desc{background:#f8fbfc;border:1px solid #e2e8f0;border-radius:6px;padding:10px 12px;font-size:13.5px;color:#334155;line-height:1.6;white-space:pre-wrap}.tien-do-timeline{display:flex;flex-direction:column;gap:0}.tien-do-item{display:flex;gap:12px;padding-bottom:16px;position:relative}.tien-do-item:not(:last-child):before{content:"";position:absolute;left:7px;top:20px;bottom:0;width:2px;background:#e2e8f0}.tien-do-dot{width:16px;height:16px;border-radius:50%;border:2px solid #e2e8f0;background:#94a3b8;flex-shrink:0;margin-top:3px;position:relative;z-index:1}.tien-do-dot.bg-red{background:#ef4444;border-color:#fca5a5}.tien-do-dot.bg-yellow{background:#f59e0b;border-color:#fcd34d}.tien-do-dot.bg-blue{background:#3b82f6;border-color:#93c5fd}.tien-do-dot.bg-green{background:#22c55e;border-color:#86efac}.tien-do-head{display:flex;gap:8px;align-items:center;margin-bottom:4px;flex-wrap:wrap}.tien-do-body{font-size:13.5px;color:#334155;line-height:1.55}.tien-do-form{background:#f8fbfc;border:1px solid #e2e8f0;border-radius:8px;padding:14px 16px;margin-top:10px;display:flex;flex-direction:column;gap:10px}.form-section-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;color:#0f766e;text-transform:uppercase;letter-spacing:0;padding:8px 0 6px;border-bottom:1px solid #e2f5f3;margin-bottom:8px}.form-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:4px}.personal-work-page{gap:18px}.personal-hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;border:1px solid #d7e1e6;border-radius:8px;padding:20px;background:linear-gradient(135deg,#fff,#f3fbf9)}.personal-hero h3{margin:12px 0 6px;font-size:24px}.personal-hero p{max-width:760px;margin:0;color:#536573}.personal-hero-rings{display:flex;gap:14px}.personal-ring{display:grid;width:116px;height:116px;place-items:center;align-content:center;border-radius:999px;background:radial-gradient(circle at center,white 0 58%,transparent 59%),conic-gradient(var(--ring) var(--value),#e5edf1 0)}.personal-ring span,.personal-ring small{grid-column:1}.personal-ring span{font-size:24px;font-weight:800;line-height:1}.personal-ring small{color:#687784;font-weight:700}.personal-metric-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.personal-metric{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;min-height:116px;border:1px solid #d7e1e6;border-radius:8px;padding:16px;background:#fff}.personal-metric-icon{display:grid;width:42px;height:42px;place-items:center;border-radius:8px}.personal-metric span,.personal-metric small{display:block}.personal-metric span{color:#52616d;font-weight:700}.personal-metric strong{display:block;margin:3px 0;font-size:30px;line-height:1.1}.personal-metric small{color:#687784}.personal-metric.tone-blue .personal-metric-icon{color:#155e75;background:#e0f2fe}.personal-metric.tone-slate .personal-metric-icon{color:#334250;background:#eef3f5}.personal-metric.tone-cyan .personal-metric-icon{color:#0f766e;background:#ccfbf1}.personal-metric.tone-green .personal-metric-icon{color:#166534;background:#dcfce7}.personal-metric.tone-red .personal-metric-icon{color:#9b241b;background:#fff1ef}.personal-metric.tone-amber .personal-metric-icon{color:#92400e;background:#fef3c7}.personal-focus-panel{padding:18px}.personal-task-list{display:grid;gap:10px}.personal-task-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,auto);gap:14px;align-items:center;border:1px solid #e2eaee;border-left:4px solid #cbd8df;border-radius:8px;padding:12px;background:#fbfdfe}.personal-task-card.overdue{border-left-color:#d92d20;background:snow}.personal-task-card.due_today{border-left-color:#d98a00;background:#fffdf7}.personal-task-card.due_soon{border-left-color:#0891b2}.personal-task-main{min-width:0}.personal-task-code{display:block;color:#687784;font-family:var(--font-mono);font-size:12px}.personal-task-main strong,.personal-task-main small{display:block}.personal-task-main strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.personal-task-main small{color:#687784}.personal-task-side{display:grid;grid-template-columns:auto auto minmax(120px,180px) auto;gap:10px;align-items:center}.personal-task-date{color:#24574f;font-weight:800;white-space:nowrap}.my-progress{display:grid;grid-template-columns:minmax(90px,1fr) 38px;gap:8px;align-items:center}.my-progress div{height:8px;overflow:hidden;border-radius:999px;background:#e5edf1}.my-progress i{display:block;height:100%;border-radius:inherit}.my-progress span{color:#334250;font-size:12px;font-weight:800}.personal-empty{display:grid;min-height:220px;place-items:center;align-content:center;gap:8px;color:#687784;text-align:center}.personal-empty strong{color:#17212b}@media(max-width:1180px){.personal-hero{grid-template-columns:1fr}.personal-metric-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.personal-task-card{grid-template-columns:1fr}.personal-task-side{grid-template-columns:auto auto minmax(150px,1fr) auto}}@media(max-width:860px){.personal-hero{grid-template-columns:1fr;align-items:stretch}.personal-hero-rings{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.personal-ring{justify-self:center}.personal-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.personal-task-main strong{white-space:normal}.personal-task-side{grid-template-columns:1fr;justify-items:start}}@media(max-width:560px){.personal-hero,.personal-focus-panel,.personal-metric{padding:14px}.personal-hero h3{font-size:20px}.personal-hero-rings,.personal-metric-grid{grid-template-columns:1fr}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;display:flex;gap:12px;align-items:center}.stat-card.stat-pending{border-left:3px solid #94a3b8}.stat-card.stat-progress{border-left:3px solid #3b82f6}.stat-card.stat-done{border-left:3px solid #22c55e}.stat-card.stat-overdue{border-left:3px solid #ef4444}.stat-card.stat-today{border-left:3px solid #f59e0b}.stat-icon{color:#0f766e;flex-shrink:0}.stat-value{font-size:22px;font-weight:700;color:#17212b;line-height:1}.stat-label{font-size:12px;color:#64748b;margin-top:2px}.urgent-list{display:flex;flex-direction:column;gap:1px}.urgent-task-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 14px;border-radius:7px;background:#fff;border:1px solid #e2e8f0;flex-wrap:wrap}.urgent-task-row.urgent-overdue{border-left:3px solid #ef4444;background:#fef9f9}.urgent-task-row.urgent-today{border-left:3px solid #f59e0b;background:#fffdf5}.urgent-task-info{display:flex;gap:8px;align-items:baseline;min-width:0;flex:1}.urgent-task-code{font-family:var(--font-mono);font-size:11.5px;color:#94a3b8;flex-shrink:0}.urgent-task-title{font-size:13.5px;font-weight:500;color:#17212b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.urgent-task-meta{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}.urgent-due{font-size:12px;color:#64748b;white-space:nowrap}.report-page{gap:18px}.report-hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;border:1px solid #d7e1e6;border-radius:8px;padding:20px;background:linear-gradient(135deg,#fff,#f5fbfb)}.report-hero h3{margin:12px 0 6px;font-size:24px}.report-hero p{max-width:780px;margin:0;color:#536573}.report-ring{display:grid;width:124px;height:124px;place-items:center;align-content:center;border-radius:999px;background:radial-gradient(circle at center,white 0 58%,transparent 59%),conic-gradient(var(--ring) var(--value),#e5edf1 0)}.report-ring span,.report-ring small{grid-column:1}.report-ring span{font-size:26px;font-weight:800;line-height:1}.report-ring small{color:#687784;font-weight:700}.report-filter-bar{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr)) auto;gap:10px;align-items:end;border:1px solid #d7e1e6;border-radius:8px;padding:14px;background:#fff}.report-filter-bar label{display:grid;gap:6px}.report-filter-bar label span{color:#52616d;font-size:12px;font-weight:800}.report-metric-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.report-metric{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;min-height:118px;border:1px solid #d7e1e6;border-radius:8px;padding:16px;background:#fff}.report-metric-icon{display:grid;width:42px;height:42px;place-items:center;border-radius:8px}.report-metric span,.report-metric small{display:block}.report-metric span{color:#52616d;font-weight:700}.report-metric strong{display:block;margin:3px 0;font-size:30px;line-height:1.1}.report-metric small{color:#687784}.report-metric.tone-blue .report-metric-icon{color:#155e75;background:#e0f2fe}.report-metric.tone-green .report-metric-icon{color:#166534;background:#dcfce7}.report-metric.tone-cyan .report-metric-icon{color:#0f766e;background:#ccfbf1}.report-metric.tone-red .report-metric-icon{color:#9b241b;background:#fff1ef}.report-metric.tone-amber .report-metric-icon{color:#92400e;background:#fef3c7}.report-metric.tone-slate .report-metric-icon{color:#334250;background:#eef3f5}.report-tabs{display:inline-flex;width:fit-content;border:1px solid #cbd8df;border-radius:8px;padding:3px;background:#fff}.report-tabs button{min-height:34px;border:0;border-radius:6px;padding:0 14px;color:#455766;background:transparent;font-weight:800}.report-tabs button.active{color:#fff;background:#0f766e}.report-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px}.report-card{min-width:0}.report-card.span-8{grid-column:span 8}.report-card.span-4{grid-column:span 4}.report-time-chart{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(42px,1fr);gap:10px;min-height:250px;overflow-x:auto;padding:12px 4px 4px}.report-time-col{display:grid;grid-template-rows:minmax(180px,1fr) auto;gap:8px;justify-items:center}.report-bar-stack{position:relative;width:32px;height:100%;align-self:end;border-radius:8px;background:#edf3f5;overflow:hidden}.report-bar-stack i{position:absolute;bottom:0;display:block;width:100%;border-radius:inherit inherit 0 0}.report-bar-stack .total{background:#dbe5ea}.report-bar-stack .done{width:58%;left:0;background:#16a34a}.report-bar-stack .late{width:42%;right:0;background:#d92d20}.report-time-col span{color:#687784;font-size:12px;font-weight:700;white-space:nowrap}.report-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}.report-legend span{display:inline-flex;align-items:center;gap:6px;color:#536573;font-size:13px;font-weight:700}.report-legend i{width:10px;height:10px;border-radius:3px}.report-legend .total{background:#dbe5ea}.report-legend .done{background:#16a34a}.report-legend .late{background:#d92d20}.report-table-wrap{overflow-x:auto}.report-table th,.report-table td{text-align:center}.report-table th:first-child,.report-table td:first-child{text-align:left}.report-progress-inline{display:grid;grid-template-columns:48px minmax(90px,1fr);gap:8px;align-items:center}.report-progress-inline span{font-weight:800}.report-progress-inline div{height:8px;overflow:hidden;border-radius:999px;background:#e5edf1}.report-progress-inline i{display:block;height:100%;border-radius:inherit}.report-bars{margin-top:4px}.text-success{color:#16a34a;font-weight:800}.text-danger{color:#d92d20;font-weight:800}.summary-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.summary-card{background:#fff;border:1px solid #e2e8f0;border-top:3px solid #94a3b8;border-radius:10px;padding:14px 16px}.summary-value{font-size:26px;font-weight:800;line-height:1;margin-bottom:4px}.summary-label{font-size:12.5px;color:#52616d;font-weight:500}.summary-sub{font-size:12px;color:#94a3b8;margin-top:2px}.chart-scroll{overflow-x:auto;padding-bottom:4px}.bar-chart-svg{display:block;overflow:visible}.chart-title{font-size:14px;font-weight:600;color:#17212b;margin:0 0 12px}.mini-bar-wrap{min-width:80px}.mini-bar-bg{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.mini-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.loading-inline{display:inline-flex;align-items:center;gap:6px;color:#64748b;font-size:13px}.text-info{color:#3b82f6}.text-warn{color:#f59e0b}.empty-state-small{text-align:center;padding:24px;color:#94a3b8;font-size:13px}.permission-layout{display:grid;grid-template-columns:minmax(300px,.38fr) minmax(0,1fr);gap:16px;min-height:560px}.permission-list,.permission-editor{border:1px solid #d9e3e8;border-radius:8px;background:#fff}.permission-list{display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;padding:14px}.permission-users{display:grid;align-content:start;gap:8px;overflow:auto;max-height:620px}.permission-user{display:grid;grid-template-columns:38px minmax(0,1fr);gap:10px;width:100%;border:1px solid #e2ebef;border-radius:8px;padding:10px;text-align:left;color:#17212b;background:#fbfdfe}.permission-user.active{border-color:#0f766e;background:#ecfdf5}.permission-user strong,.permission-user small,.permission-user em{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.permission-user small{margin-top:2px;color:#52616d;font-size:12px}.permission-user em{margin-top:5px;color:#0f766e;font-size:12px;font-style:normal;font-weight:700}.permission-avatar{display:grid;width:38px;height:38px;place-items:center;border-radius:8px;color:#fff;background:#174b59;font-weight:800}.permission-editor{display:grid;align-content:start;gap:18px;padding:18px}.permission-header,.permission-title,.linked-profile{display:flex;align-items:center}.permission-header{justify-content:space-between;gap:16px}.permission-title{gap:12px}.permission-title h2{margin:0;font-size:21px}.permission-title p{margin:4px 0 0;color:#52616d}.linked-profile{gap:9px;border:1px solid #d9e3e8;border-radius:8px;padding:11px 12px;color:#52616d;background:#f8fafb}.role-check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.role-check{display:grid;grid-template-columns:26px minmax(0,1fr);gap:10px;align-items:center;min-height:74px;border:1px solid #d9e3e8;border-radius:8px;padding:12px;text-align:left;color:#17212b;background:#fff}.role-check.checked{border-color:#0f766e;background:#ecfdf5}.role-check>span{display:grid;width:24px;height:24px;place-items:center;border:1px solid #c9d6dc;border-radius:6px;color:#fff;background:#fff}.role-check.checked>span{border-color:#0f766e;background:#0f766e}.role-check strong,.role-check small{grid-column:2}.role-check small{color:#64748b}.empty-note{margin:18px 0;color:#64748b;text-align:center}@media(max-width:768px){.task-board-hero,.task-metric-grid{grid-template-columns:1fr}.task-table-head,.cv-filter-head{align-items:flex-start;flex-direction:column}.cv-filter-bar{grid-template-columns:1fr}.cv-filter-bar{flex-direction:column;align-items:stretch}.cv-filter-bar input,.cv-filter-bar select{width:100%}.kanban-board{flex-direction:column}.kanban-col{flex:none;width:100%}.detail-grid,.permission-layout{grid-template-columns:1fr}.stats-grid,.summary-cards{grid-template-columns:1fr 1fr}.urgent-task-row{flex-direction:column;align-items:flex-start}.modal-panel{width:98vw;max-height:95vh;border-radius:8px}}@media(min-width:769px)and (max-width:1180px){.task-board-hero{grid-template-columns:1fr}.task-metric-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.cv-filter-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.cv-search-input,.cv-filter-bar .secondary-button{grid-column:1 / -1}}.hscv-tree-page{display:grid;grid-template-columns:280px 1fr;gap:0;height:calc(100vh - 57px);overflow:hidden;background:#fff;border:1px solid #d7e1e6;border-radius:8px}.hscv-tree-panel{border-right:1px solid #d7e1e6;display:flex;flex-direction:column;overflow:hidden}.hscv-tree-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #d7e1e6;font-size:13px;background:#f8fafb}.btn-icon-sm{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid #d7e1e6;border-radius:6px;background:#fff;cursor:pointer;color:#374151;transition:background .15s}.btn-icon-sm:hover{background:#f0f4f8}.hscv-tree-loading,.hscv-tree-error{padding:20px 14px;font-size:13px;color:#687784;display:flex;align-items:center;gap:8px}.hscv-tree-error{color:#dc2626}.folder-tree{list-style:none;margin:0;padding:8px 0;overflow-y:auto;flex:1;font-size:13px}.folder-children{list-style:none;margin:0;padding:0 0 0 16px}.folder-empty{padding:16px 14px;color:#687784;font-size:13px}.folder-node{display:flex;align-items:center;gap:4px;width:100%;padding:5px 8px 5px 6px;border:none;background:none;cursor:pointer;border-radius:5px;text-align:left;color:#1e293b;transition:background .12s}.folder-node:hover{background:#f0f4f8}.folder-node.selected{background:#1d4ed8;color:#fff}.folder-node.selected .folder-icon{color:#fff}.folder-node.selected .folder-inactive{background:#fff3;color:#fff}.folder-toggle{display:inline-flex;align-items:center;justify-content:center;width:16px;flex-shrink:0;color:#94a3b8}.folder-node.selected .folder-toggle{color:#ffffffb3}.folder-icon{flex-shrink:0}.folder-icon.has-children,.folder-icon.open{color:#f59e0b}.folder-icon.leaf{color:#cbd5e1}.folder-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-inactive{font-size:10px;background:#f1f5f9;color:#94a3b8;padding:1px 5px;border-radius:3px;flex-shrink:0}.hscv-detail-panel{overflow-y:auto;padding:20px}.hscv-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;height:100%;color:#687784;font-size:14px}.hscv-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.hscv-detail-title{display:flex;align-items:center;gap:10px}.hscv-detail-title h3{font-size:18px;font-weight:600;margin:0}.hscv-detail-list{display:grid;grid-template-columns:140px 1fr;gap:10px 16px;font-size:13px;margin-bottom:24px;background:#f8fafb;border:1px solid #e2e8f0;border-radius:8px;padding:14px 16px}.hscv-detail-list dt{color:#687784;font-weight:500}.hscv-detail-list dd{margin:0;color:#1e293b}.hscv-status{display:inline-flex;align-items:center;font-size:12px;padding:2px 8px;border-radius:4px}.hscv-status.active{background:#f0fdf4;color:#16a34a}.hscv-status.inactive{background:#f1f5f9;color:#94a3b8}.hscv-children-section{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.hscv-children-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f8fafb;font-size:13px;font-weight:500;border-bottom:1px solid #e2e8f0}.btn-text{display:inline-flex;align-items:center;gap:4px;border:none;background:none;cursor:pointer;color:#2563eb;font-size:12px;padding:2px 4px}.btn-text:hover{text-decoration:underline}.hscv-no-children{padding:14px;color:#94a3b8;font-size:13px;margin:0}.hscv-children-list{list-style:none;margin:0;padding:4px 0}.hscv-child-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 14px;border:none;background:none;cursor:pointer;text-align:left;font-size:13px;color:#1e293b;transition:background .12s}.hscv-child-item:hover{background:#f0f4f8}.hscv-form{display:flex;flex-direction:column;gap:16px}.hscv-form-header{display:flex;align-items:center;justify-content:space-between}.hscv-form-header h3{font-size:16px;font-weight:600;margin:0}.hscv-form-footer{display:flex;justify-content:flex-end;gap:8px}.checkbox-label{display:flex;align-items:center;gap:8px;flex-direction:row!important}.checkbox-label input[type=checkbox]{width:auto;flex-shrink:0}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover{background:#fee2e2}@media(max-width:768px){.hscv-tree-page{grid-template-columns:1fr;height:auto}.hscv-tree-panel{border-right:none;border-bottom:1px solid #d7e1e6;max-height:40vh}}.hscv-page{display:grid;grid-template-columns:minmax(340px,38%) minmax(0,1fr);height:calc(100vh - 112px);min-height:640px;overflow:hidden;border:1px solid #d7e1e6;border-radius:8px;background:#fff;box-shadow:0 18px 48px #17212b14}.hscv-tree{display:flex;min-width:0;min-height:0;flex-direction:column;border-right:1px solid #d7e1e6;background:#fbfdfe}.hscv-tree-head{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:78px;border-bottom:1px solid #e1eaee;padding:16px 18px;background:#fff}.hscv-tree-head p{margin:0 0 4px;color:#687784;font-size:12px;font-weight:800;text-transform:uppercase}.hscv-tree-head h2{margin:0;color:#17212b;font-size:20px;line-height:1.2}.hscv-tree-head>span{flex:0 0 auto;border:1px solid #cfe3df;border-radius:999px;padding:5px 10px;color:#24574f;background:#edf8f5;font-size:12px;font-weight:800}.hscv-tree-toolbar{display:grid;grid-template-columns:minmax(0,1fr) 34px 34px;gap:8px;align-items:center;border-bottom:1px solid #e1eaee;padding:12px;background:#f5f9fa}.hscv-search{display:flex;align-items:center;gap:8px;min-width:0;height:34px;border:1px solid #ccd9df;border-radius:6px;padding:0 9px;color:#687784;background:#fff}.hscv-search input{min-width:0;border:0;padding:0;background:transparent;box-shadow:none;font-size:13px}.hscv-search-clear,.btn-ghost{display:inline-flex;align-items:center;justify-content:center;border:0;background:transparent}.hscv-search-clear{width:20px;height:20px;border-radius:4px;color:#687784}.btn-ghost{width:34px;height:34px;border:1px solid #ccd9df;border-radius:6px;color:#334250;background:#fff}.btn-ghost:hover,.hscv-search-clear:hover{color:#0f766e;background:#eef9f7}.hscv-tree-body{min-height:0;flex:1;overflow:auto;padding:10px 8px 18px}.hscv-tree-state{display:flex;align-items:center;gap:8px;margin:10px;border:1px dashed #cbd8df;border-radius:8px;padding:14px;color:#687784;background:#fff;font-size:13px}.hscv-tree-state--error{border-color:#f0c9c9;color:#9c2626;background:#fff7f7}.tree-root-row,.tree-row{position:relative;display:grid;grid-template-columns:18px 20px minmax(0,1fr) auto auto;align-items:center;gap:5px;min-height:36px;border-radius:6px;padding:0 7px 0 calc(8px + var(--depth, 0) * 22px);color:#334250;font-size:13px;font-weight:750}.tree-root-row{--depth: 0;margin-bottom:3px;color:#17212b;background:#fff}.tree-row{cursor:pointer}.tree-row:hover{background:#eef5f7}.tree-row--selected{color:#0f4f49;background:#dff5ef;box-shadow:inset 3px 0 #0f766e}.tree-guide{position:absolute;top:0;bottom:0;left:calc(18px + var(--guide-index, 0) * 22px);width:1px;background:transparent}.tree-arrow{display:inline-flex;align-items:center;justify-content:center;width:18px;height:24px;border:0;padding:0;color:#687784;background:transparent}.tree-icon{display:inline-flex;align-items:center;justify-content:center;color:#f7b500}.fi{flex:0 0 auto;stroke-width:2.2}.fi--open,.fi--has-children{color:#f7b500;fill:#fff2b8}.fi--leaf{color:#f7b500;fill:#fff}.tree-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-count,.tree-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:20px;border-radius:999px;padding:0 7px;font-size:11px;font-weight:800}.tree-count{color:#52616d;background:#edf2f5}.tree-badge--off{color:#8a4b00;background:#fff4df}.tree-add-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid transparent;border-radius:6px;color:transparent;background:transparent}.tree-row:hover .tree-add-btn,.tree-row--selected .tree-add-btn{border-color:#c8ded8;color:#0f766e;background:#fff}.hscv-main{min-width:0;min-height:0;overflow:auto;background:#f6fafb}.hscv-detail,.hscv-form,.hscv-empty{display:grid;gap:16px;padding:22px}.hscv-summary-strip{display:flex;flex-wrap:wrap;gap:8px}.hscv-summary-strip span{display:inline-flex;align-items:center;gap:5px;min-height:30px;border:1px solid #d8e6e2;border-radius:999px;padding:4px 10px;color:#52616d;background:#fff;font-size:12px;font-weight:700}.hscv-summary-strip strong{color:#0f766e}.hscv-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:4px;color:#687784;font-size:12px;font-weight:700}.hscv-bc-root,.hscv-bc-item{display:inline-flex;align-items:center;gap:4px;max-width:100%}.hscv-bc-item{min-width:0}.hscv-bc-item:last-child{color:#334250}.hscv-bc-sep{flex:0 0 auto;color:#9aabb5}.hscv-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;border:1px solid #d7e1e6;border-radius:8px;padding:18px;background:#fff}.hscv-detail-title{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0}.hscv-detail-title h2{min-width:0;margin:0;color:#17212b;font-size:22px;line-height:1.25;overflow-wrap:anywhere}.hscv-detail-actions,.hscv-form-foot{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.hscv-pill{display:inline-flex;align-items:center;justify-content:center;min-height:24px;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:800;white-space:nowrap}.hscv-pill--on{color:#17603a;background:#e9f9ef}.hscv-pill--off{color:#8a4b00;background:#fff4df}.hscv-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.hscv-detail-card,.hscv-children,.hscv-form{border:1px solid #d7e1e6;border-radius:8px;background:#fff}.hscv-detail-card{display:grid;gap:6px;min-height:82px;padding:14px}.hscv-detail-card-label{color:#687784;font-size:12px;font-weight:800;text-transform:uppercase}.hscv-detail-card-value{min-width:0;color:#17212b;font-weight:750;overflow-wrap:anywhere}.muted{color:#687784;font-style:normal}.hscv-children{overflow:hidden}.hscv-children-head{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:48px;border-bottom:1px solid #e1eaee;padding:0 14px;color:#334250;font-size:13px;font-weight:800}.btn-text-sm{display:inline-flex;align-items:center;gap:5px;border:0;border-radius:6px;padding:6px 8px;color:#0f766e;background:transparent;font-size:12px;font-weight:800}.btn-text-sm:hover{background:#eef9f7}.hscv-no-children{margin:0;padding:16px;color:#687784;font-size:13px}.hscv-children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px;padding:14px}.hscv-child-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:9px;min-height:44px;border:1px solid #e0e8ec;border-radius:8px;padding:9px 10px;color:#334250;background:#fbfdfe;text-align:left;font-size:13px;font-weight:750}.hscv-child-card:hover{border-color:#b9d6cd;background:#f0faf7}.hscv-child-card span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hscv-empty{min-height:100%;place-items:center;align-content:center;color:#687784;text-align:center}.hscv-empty p{margin:0;font-weight:700}.hscv-form{max-width:760px;margin:22px;padding:0;overflow:hidden}.hscv-form-head{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:62px;border-bottom:1px solid #e1eaee;padding:0 18px;background:#fff}.hscv-form-head h3{margin:0;color:#17212b;font-size:18px}.hscv-form-body{display:grid;gap:14px;padding:18px}.form-field{display:grid;gap:7px}.form-field>span{margin:0}.req{display:inline;color:#ba1a1a}.form-row-2{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,auto);gap:14px;align-items:end}.form-field--check{display:flex;align-items:center;min-height:42px;border:1px solid #d7e1e6;border-radius:6px;padding:0 12px;background:#f8fbfc}.form-field--check input{width:auto;margin:0 8px 0 0}.form-field--check span{margin:0}.form-error{margin:0;border:1px solid #f0c9c9;border-radius:6px;padding:10px 12px;color:#9c2626;background:#fff7f7;font-size:13px;font-weight:700}.hscv-form-foot{border-top:1px solid #e1eaee;padding:14px 18px;background:#f8fbfc}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:36px;border-radius:6px;padding:0 12px;font-size:13px;font-weight:800}.btn-primary{border:1px solid #0f766e;color:#fff;background:#0f766e}.btn-primary:hover{background:#0b625b}.btn-secondary{border:1px solid #cbd8df;color:#263642;background:#fff}.btn-secondary:hover{border-color:#0f766e;color:#0f766e;background:#eef9f7}.btn-danger{border:1px solid #f0c9c9;color:#9c2626;background:#fff7f7}.btn-danger:hover{background:#ffecec}@media(max-width:1100px){.hscv-page{grid-template-columns:minmax(310px,42%) minmax(0,1fr)}.hscv-cards{grid-template-columns:1fr}}@media(max-width:760px){.hscv-page{grid-template-columns:1fr;height:auto;min-height:0}.hscv-tree{border-right:0;border-bottom:1px solid #d7e1e6;max-height:52vh}.hscv-detail,.hscv-empty{padding:16px}.hscv-detail-head{display:grid}.hscv-detail-title{grid-template-columns:auto minmax(0,1fr)}.hscv-detail-title .hscv-pill{grid-column:2;justify-self:start}.hscv-detail-actions,.hscv-form-foot{justify-content:stretch}.hscv-detail-actions .btn,.hscv-form-foot .btn{flex:1 1 140px}.hscv-form{margin:16px}.form-row-2{grid-template-columns:1fr}}.qperm-row>td{padding:0;background:#f7fafb;border-bottom:2px solid #e5edf1}.qperm-loading{display:flex;align-items:center;gap:8px;padding:12px 16px;color:#687784;font-size:13px}.qperm-panel{padding:12px 16px 14px}.qperm-groups{display:flex;gap:16px;flex-wrap:wrap}.qperm-group{flex:1;min-width:200px}.qperm-group h4{font-size:11px;font-weight:800;color:#5b6b78;margin:0 0 6px;text-transform:uppercase;letter-spacing:0}.qperm-empty{font-size:12px;color:#94a3b8;margin:0}.qperm-inner{width:100%;border-collapse:collapse;font-size:12px}.qperm-inner th,.qperm-inner td{padding:4px 8px;border-bottom:1px solid #edf2f5;text-align:left}.qperm-inner th{color:#5b6b78;font-weight:700;background:#edf2f5}.qperm-actions{margin-top:10px;display:flex;justify-content:flex-end}.user-chip-wrap{position:relative}.user-chip{cursor:pointer}.user-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:200;min-width:200px;background:#fff;border:1px solid #d4e0e5;border-radius:8px;box-shadow:0 4px 16px #0000001a;overflow:hidden}.user-dropdown-info{padding:12px 14px 8px;font-size:13px;color:#5a7282;border-bottom:1px solid #eef2f4}.user-dropdown-info strong{display:block;color:#17212b;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-item{display:flex;align-items:center;gap:9px;width:100%;padding:10px 14px;border:0;background:transparent;font-size:13.5px;color:#17212b;cursor:pointer;text-align:left;transition:background .12s}.user-dropdown-item:hover{background:#f0f5f7}.user-dropdown-item.danger{color:#ba1a1a}.user-dropdown-item.danger:hover{background:#fff1f1}.user-dropdown-divider{height:1px;background:#eef2f4;margin:2px 0}.form-section{background:#fff;border:1px solid #e0eaee;border-radius:8px;padding:20px 20px 16px}.form-section-title{font-size:14px;font-weight:600;color:#17212b;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #eef2f4}.form-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field-group{display:flex;flex-direction:column;gap:5px}.field-label{font-size:12.5px;font-weight:600;color:#4a6475;letter-spacing:0}.required-star{color:#ba1a1a;margin-left:2px}.field-input{height:36px;padding:0 10px;border:1px solid #ccd9e0;border-radius:5px;font-size:13.5px;color:#17212b;background:#fff;outline:none;transition:border-color .14s}.field-input:focus{border-color:#17a2b8}.field-input[readonly],.field-input:read-only{background:#f5f8fa;color:#5a7282;cursor:default}.inline-error{padding:10px 13px;border:1px solid #f5c2c2;border-radius:6px;background:#fff4f4;color:#ba1a1a;font-size:13px}.image-upload-card{display:grid;gap:10px}.image-upload-area{min-height:140px;border:1.5px dashed #c8d8e0;border-radius:6px;background:#f7fafc;display:flex;align-items:center;justify-content:center;overflow:hidden}.image-upload-area:has(.preview-image){border-style:solid;background:#fff}.image-upload-area:hover{border-color:#8bbfba;background:#f2fbf9}.preview-image{width:100%;height:100%;object-fit:contain;max-height:140px}.image-placeholder{font-size:13px;color:#9ab0bc}.image-upload-actions{display:flex;align-items:center;gap:8px}.image-picker{position:relative;flex:1;min-height:36px;overflow:hidden}.image-picker span{margin:0;color:inherit;font-size:13px}.image-picker input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.notification-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 24px}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:13.5px;color:#17212b;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:#17a2b8;cursor:pointer;flex-shrink:0}.resource-commandbar-title{font-size:15px;font-weight:600;color:#17212b}.toast-success{border:1px solid #bfe5d7;border-radius:6px;padding:11px 13px;color:#0d5f45;background:#effbf6;font-size:13.5px}@media(max-width:768px){.form-grid-2,.notification-grid{grid-template-columns:1fr}}.profile-form-rows{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.profile-field{display:flex;flex-direction:column;gap:5px}.profile-form-rows .profile-field .field-label{height:18px;display:flex;align-items:center}@media(max-width:768px){.profile-form-rows{grid-template-columns:1fr}}.notif-wrap,.notif-bell{position:relative}.notif-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-danger, #e53e3e);color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;pointer-events:none}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:10px;box-shadow:0 8px 32px #00000021;z-index:200;display:flex;flex-direction:column;overflow:hidden}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border, #e2e8f0);gap:8px;flex-shrink:0}.notif-panel-title{font-weight:600;font-size:14px}.notif-mark-all{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--color-primary, #3182ce);font-size:12px;padding:2px 6px;border-radius:4px;white-space:nowrap}.notif-mark-all:hover{background:var(--color-muted-bg, #f0f4f8)}.notif-mark-all:disabled{opacity:.5;cursor:default}.notif-list{flex:1;overflow-y:auto}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 16px;color:var(--color-muted, #718096);font-size:13px}.notif-item{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--color-border, #e2e8f0);padding:12px 16px;cursor:pointer;transition:background .15s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--color-muted-bg, #f7fafc)}.notif-item.is-read{opacity:.65;cursor:default}.notif-dot{flex-shrink:0;margin-top:6px;width:8px;height:8px;border-radius:50%;background:var(--color-primary, #3182ce)}.notif-item-body{flex:1;min-width:0}.notif-item-tag{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0;color:var(--color-primary, #3182ce);margin-bottom:2px}.notif-item-title{font-size:13px;font-weight:500;line-height:1.4;margin-bottom:2px;color:var(--color-text, #1a202c);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item-content{font-size:12px;color:var(--color-muted, #718096);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px}.notif-item-time{font-size:11px;color:var(--color-muted, #718096)}@media(max-width:500px){.notif-panel{width:calc(100vw - 16px);right:-8px}}.attach-field{display:flex;flex-direction:column;gap:6px}.attach-current{display:flex;align-items:center;gap:5px;font-size:13px;color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:5px 10px}.attach-current a{color:#2563eb;text-decoration:underline;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.attach-clear{margin-left:auto;background:none;border:none;cursor:pointer;color:#9ca3af;font-size:13px;padding:0 2px;line-height:1}.attach-clear:hover{color:#ef4444}.attach-picker{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;color:#374151;background:#f9fafb;border:1px dashed #d1d5db;border-radius:6px;padding:6px 12px;transition:background .15s,border-color .15s}.attach-picker:hover{background:#f0f4ff;border-color:#93c5fd}.attach-picker input[type=file]{display:none}.attach-table-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:#2563eb;text-decoration:none;max-width:180px;overflow:hidden}.attach-table-link span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-table-link:hover{text-decoration:underline}.cell-muted{font-size:12px;color:#9ca3af}.org-summary-chips{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.org-chip{display:inline-flex;align-items:center;gap:5px;background:#f1f5f9;color:#475569;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:500}.org-import-panel{display:grid;gap:18px;border-color:#c8dde7}.org-import-panel .sync-layout{margin-top:0}.org-tabs{display:flex;gap:4px}.org-tab-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;border:1.5px solid #e2e8f0;background:#fff;color:#64748b;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.org-tab-btn:hover{background:#f8fafc;border-color:#cbd5e1}.org-tab-btn.active{background:#eff6ff;border-color:#3b82f6;color:#1d4ed8}.org-tree-list{padding:12px 16px;display:flex;flex-direction:column;gap:6px}.org-tree-node{border-radius:8px;border:1px solid #e2e8f0;overflow:hidden}.org-node-header{width:100%;display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f8fafc;border:none;cursor:pointer;text-align:left;font-size:14px;font-weight:600;color:#1e293b;transition:background .15s}.org-node-header:hover:not(:disabled){background:#f1f5f9}.org-node-header:disabled{cursor:default;color:#94a3b8}.org-node-header.is-open{background:#eff6ff;color:#1d4ed8;border-bottom:1px solid #dbeafe}.org-node-chevron{color:#94a3b8;display:flex;flex-shrink:0}.org-node-icon{color:#64748b;flex-shrink:0}.org-node-header.is-open .org-node-icon{color:#3b82f6}.org-node-label{flex:1}.org-node-badge-extra{font-size:11px;font-weight:500;color:#94a3b8;background:#f1f5f9;border-radius:4px;padding:1px 6px;font-family:var(--font-mono)}.org-node-count{font-size:12px;font-weight:400;color:#64748b;background:#e2e8f0;border-radius:20px;padding:2px 9px;flex-shrink:0}.org-node-children{background:#fff;padding:6px 0;display:flex;flex-direction:column}.org-staff-row{display:flex;align-items:center;gap:10px;padding:7px 16px 7px 40px;transition:background .1s}.org-staff-row:hover{background:#f8fafc}.org-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.org-staff-info{flex:1;display:flex;align-items:center;gap:7px;flex-wrap:wrap;min-width:0}.org-staff-name{font-size:13px;font-weight:600;color:#1e293b}.org-role-badge{min-height:24px;border:1px solid transparent;padding:0 9px;font-size:12px;box-shadow:0 1px #0f172a0a}.org-role-badge.danger{border-color:#fecaca;color:#b91c1c;background:#fee2e2}.org-role-badge.warning{border-color:#fed7aa;color:#c2410c;background:#ffedd5}.org-role-badge.info{border-color:#bfdbfe;color:#1d4ed8;background:#dbeafe}.org-role-badge.success{border-color:#bbf7d0;color:#15803d;background:#dcfce7}.org-role-badge.neutral{border-color:#cbd5e1;color:#475569;background:#f1f5f9}.org-staff-dept{font-size:11px;color:#64748b;background:#f1f5f9;border-radius:4px;padding:1px 6px}.org-staff-email{font-size:12px;color:#94a3b8;font-family:var(--font-mono);flex-shrink:0;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
