@import"https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap";.fcm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f19b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fcmFadeIn .2s ease}@keyframes fcmFadeIn{0%{opacity:0}to{opacity:1}}.fcm-modal{background:#fafafa;border-radius:20px;width:min(96vw,1060px);height:min(90vh,740px);display:flex;flex-direction:column;box-shadow:0 32px 80px #00000059;overflow:hidden;animation:fcmSlideUp .28s cubic-bezier(.22,1,.36,1)}@keyframes fcmSlideUp{0%{opacity:0;transform:translateY(22px) scale(.98)}to{opacity:1;transform:none}}.fcm-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px;background:#fff;border-bottom:1px solid #f0f0f0;flex-shrink:0}.fcm-header-left{display:flex;align-items:center;gap:14px}.fcm-hicon{width:42px;height:42px;background:linear-gradient(135deg,#c0392b,#96281b);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 14px #c0392b4d;flex-shrink:0}.fcm-title{font-family:Sora,sans-serif;font-size:17px;font-weight:800;color:#111;letter-spacing:-.3px}.fcm-sub{font-size:12px;color:#888;margin-top:2px}.fcm-close{width:34px;height:34px;border-radius:9px;border:1.5px solid #e8e8e8;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:#666;font-size:17px;transition:background .15s,border-color .15s,color .15s;flex-shrink:0;line-height:1}.fcm-close:hover{background:#fee2e2;border-color:#fca5a5;color:#c0392b}.fcm-toolbar{display:flex;align-items:center;gap:7px;padding:9px 24px;background:#fff;border-bottom:1px solid #f0f0f0;flex-shrink:0;flex-wrap:wrap}.tb-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;border:1.5px solid #e8e8e8;background:#fff;font-size:12px;font-weight:600;color:#444;cursor:pointer;font-family:DM Sans,sans-serif;white-space:nowrap;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s}.tb-btn:hover{background:#f5f5f5;border-color:#d0d0d0}.tb-btn.primary{background:linear-gradient(135deg,#c0392b,#96281b);border-color:transparent;color:#fff;box-shadow:0 3px 10px #c0392b40}.tb-btn.primary:hover{box-shadow:0 4px 16px #c0392b66;transform:translateY(-1px)}.tb-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.tb-sep{width:1px;height:22px;background:#ebebeb;margin:0 1px;flex-shrink:0}.fcm-legend{display:flex;align-items:center;gap:12px;margin-left:auto;flex-wrap:wrap}.leg-item{display:flex;align-items:center;gap:5px;font-size:11px;color:#666;font-weight:600}.leg-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0}.fcm-canvas{flex:1;overflow:hidden;position:relative;background-color:#f0f3f7;background-image:linear-gradient(0deg,transparent 24px,#dde3ea 25px,transparent 26px),linear-gradient(90deg,transparent 24px,#dde3ea 25px,transparent 26px);background-size:25px 25px;user-select:none;-webkit-user-select:none}.fcm-canvas svg{display:block;width:100%;height:100%;user-select:none;-webkit-user-select:none}.fcm-loading-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#f0f3f7f2;z-index:20}.fcm-spinner{width:40px;height:40px;border:3px solid #e8e8e8;border-top-color:#c0392b;border-radius:50%;animation:fcmSpin .75s linear infinite}@keyframes fcmSpin{to{transform:rotate(360deg)}}.fcm-loading-text{font-size:13px;color:#888;font-weight:500}.fcm-error-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#f0f3f7f2;z-index:20}.fcm-error-icon{font-size:36px}.fcm-error-msg{font-size:13px;color:#c0392b;font-weight:600;max-width:300px;text-align:center}.fcm-error-retry{padding:8px 18px;border-radius:8px;background:linear-gradient(135deg,#c0392b,#96281b);border:none;color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif}.fcm-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#fff;border-top:1px solid #f0f0f0;flex-shrink:0}.fcm-finfo{font-size:12.5px;color:#888}.fcm-finfo strong{color:#444;font-weight:600}.fcm-fbtns{display:flex;gap:10px}.btn-cancel{padding:9px 20px;border-radius:10px;border:1.5px solid #e0e0e0;background:#fff;font-size:13.5px;font-weight:600;color:#555;cursor:pointer;transition:background .15s;font-family:DM Sans,sans-serif}.btn-cancel:hover{background:#f5f5f5}.btn-confirm{padding:9px 22px;border-radius:10px;background:linear-gradient(135deg,#c0392b,#96281b);border:none;color:#fff;font-size:13.5px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;font-family:Sora,sans-serif;box-shadow:0 4px 14px #c0392b4d}.btn-confirm:hover{transform:translateY(-1px);box-shadow:0 6px 20px #c0392b6b}.btn-confirm:disabled{opacity:.5;cursor:not-allowed;transform:none}.zoom-badge{position:absolute;bottom:14px;right:14px;background:#fffffff0;border:1px solid #e0e0e0;border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600;color:#666;pointer-events:none;z-index:10}.hint-badge{position:absolute;bottom:14px;left:14px;background:#ffffffe6;border:1px solid #e0e0e0;border-radius:8px;padding:6px 12px;font-size:10.5px;color:#888;pointer-events:none;z-index:10;line-height:1.9}.hint-badge strong{color:#555}.node-group{cursor:default}.fcm-canvas text,.fcm-canvas tspan{user-select:none;-webkit-user-select:none;pointer-events:none}.card-bg{filter:drop-shadow(0 3px 8px rgba(0,0,0,.09));transition:filter .15s,stroke .15s}.node-group:hover .card-bg{filter:drop-shadow(0 7px 20px rgba(0,0,0,.16))}.link-dot{opacity:0;cursor:crosshair;transition:opacity .15s}.node-group:hover .link-dot{opacity:1}.del-node-btn{opacity:0;cursor:pointer;transition:opacity .15s}.node-group:hover .del-node-btn{opacity:1}.drag-hit{fill:transparent;cursor:grab}.drag-hit:active{cursor:grabbing}.node-group.node-unknown .card-bg{stroke-dasharray:5 3}.edge-group{cursor:default}.edge-vis{fill:none;stroke:#8b5cf6;stroke-width:1.8;opacity:.4;transition:stroke .15s,stroke-width .15s,opacity .15s;pointer-events:none}.edge-group:hover .edge-vis{stroke:#c0392b;stroke-width:2.5;opacity:.92}.edge-hit{fill:none;stroke:transparent;stroke-width:18;cursor:pointer}.del-edge-btn{opacity:0;cursor:pointer;transition:opacity .15s}.edge-group:hover .del-edge-btn{opacity:1}.ghost-line{fill:none;stroke:#c0392b;stroke-width:2;stroke-dasharray:6 4;opacity:.75;pointer-events:none}:root{--red: #C53030;--red-light: #FEF2F2;--navy: #1E3A5F;--navy-mid: #2D4E6E;--text: #1A202C;--text-mid: #4A5568;--text-soft: #718096;--border: #E2E8F0;--bg: #F7F9FC;--white: #FFFFFF;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.1)}.mis-page{min-height:100vh;background:var(--bg);padding:0 0 48px;font-family:Inter,DM Sans,system-ui,sans-serif}.mis-topbar{background:var(--white);border-bottom:1px solid var(--border);padding:24px 32px 20px;display:flex;align-items:flex-end;justify-content:space-between}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-soft);margin-bottom:6px}.breadcrumb a{color:var(--red);text-decoration:none;font-weight:500}.breadcrumb a:hover{text-decoration:underline}.mis-title{font-size:22px;font-weight:700;color:var(--navy);margin:0 0 2px;letter-spacing:-.3px}.mis-sub{font-size:13px;color:var(--text-soft);margin:0}.sync-banner{display:flex;align-items:center;gap:10px;padding:10px 32px;background:#ebf8ff;border-bottom:1px solid #BEE3F8;font-size:13px;color:#2c5282}.sync-banner.stale{background:#fffbeb;border-color:#fbd38d;color:#744210}.sync-icon{font-size:15px}.sync-text{flex:1}.sync-btn{padding:5px 14px;border-radius:6px;border:1px solid #90CDF4;background:var(--white);color:#2b6cb0;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.sync-btn:hover:not(:disabled){background:#ebf8ff}.sync-btn:disabled{opacity:.5;cursor:not-allowed}.mis-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;padding:24px 32px 0}.mis-stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}.mis-stat-value{font-size:28px;font-weight:700;line-height:1;margin-bottom:4px;font-variant-numeric:tabular-nums}.mis-stat-label{font-size:12px;color:var(--text-soft);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.mis-filters{display:flex;align-items:flex-end;gap:16px;padding:20px 32px;background:var(--white);margin:20px 32px 0;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);flex-wrap:wrap}.mis-filter-group{display:flex;flex-direction:column;gap:4px}.mis-filter-label{font-size:11px;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.5px}.mis-select{height:36px;padding:0 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;color:var(--text);background:var(--white);cursor:pointer;min-width:160px;outline:none;transition:border .15s}.mis-select:focus{border-color:var(--red)}.mis-search-group{flex:1;min-width:200px}.mis-search-wrap{position:relative;display:flex;align-items:center}.mis-search-icon{position:absolute;left:10px;color:var(--text-soft);font-size:16px;pointer-events:none}.mis-search{width:100%;height:36px;padding:0 32px;border:1px solid var(--border);border-radius:6px;font-size:13px;color:var(--text);outline:none;transition:border .15s}.mis-search:focus{border-color:var(--red)}.mis-search-clear{position:absolute;right:8px;background:none;border:none;color:var(--text-soft);cursor:pointer;font-size:12px;padding:2px 4px}.mis-filter-actions{display:flex;align-items:center;gap:12px;margin-left:auto}.mis-clear-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--border);background:var(--white);color:var(--text-mid);font-size:12px;cursor:pointer;transition:all .15s}.mis-clear-btn:hover{background:var(--bg);border-color:#cbd5e0}.mis-record-count{font-size:12px;color:var(--text-soft);white-space:nowrap}.mis-table-wrap{margin:16px 32px 0;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.mis-table{width:100%;border-collapse:collapse;font-size:13px}.mis-table thead tr{background:#f8fafc;border-bottom:1px solid var(--border)}.mis-table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.mis-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.mis-row:last-child{border-bottom:none}.mis-row:hover{background:#f8fafc}.mis-row.active{background:#fff5f5}.mis-row.fading{opacity:.5}.mis-table td{padding:12px 16px;color:var(--text);vertical-align:middle}.quarter-chip{display:inline-block;padding:3px 8px;border-radius:4px;background:var(--navy);color:var(--white);font-size:11px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.emp-cell{display:flex;align-items:center;gap:8px}.emp-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);color:var(--white);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.emp-name{font-weight:500;color:var(--text)}.role-chip{display:inline-block;padding:2px 8px;border-radius:4px;background:#edf2f7;color:var(--navy);font-size:11px;font-weight:700}.project-cell{max-width:200px}.project-name{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:200px}.manager-cell{color:var(--text-mid)}.na-text{color:#cbd5e0}.mis-badge{display:inline-block;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.reminder-none{color:#cbd5e0;font-size:14px}.reminder-dots-wrap{display:flex;align-items:center;gap:6px}.reminder-count{font-size:13px;font-weight:700;color:var(--red);min-width:16px}.reminder-dots{display:flex;align-items:center;gap:2px}.rdot{display:block;width:6px;height:6px;border-radius:50%;background:var(--red)}.rdot-more{font-size:10px;color:var(--red);font-weight:600}.mis-loading-cell,.mis-empty-cell{padding:60px 20px!important;text-align:center;color:var(--text-soft);font-size:14px}.mis-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 12px}.mis-empty-icon{font-size:32px;margin-bottom:8px}.mis-empty-sub{font-size:12px;color:#cbd5e0;margin-top:4px}.mis-error{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff5f5;border-bottom:1px solid #FED7D7;color:var(--red);font-size:13px}.mis-error button{padding:4px 12px;border-radius:4px;border:1px solid var(--red);background:var(--white);color:var(--red);font-size:12px;cursor:pointer}.mis-pagination{display:flex;align-items:center;gap:6px;padding:14px 16px;border-top:1px solid var(--border);background:#fafafa}.pag-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--border);background:var(--white);color:var(--text-mid);font-size:12px;cursor:pointer;transition:all .15s}.pag-btn:hover:not(:disabled){border-color:var(--red);color:var(--red)}.pag-btn:disabled{opacity:.4;cursor:not-allowed}.pag-pages{display:flex;gap:4px}.pag-num{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:var(--white);font-size:12px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.pag-num:hover{border-color:var(--red);color:var(--red)}.pag-num.active{background:var(--red);border-color:var(--red);color:var(--white);font-weight:700}.pag-info{margin-left:auto;font-size:12px;color:var(--text-soft)}.side-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;z-index:400;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.side-panel{position:fixed;top:0;right:0;bottom:0;width:400px;background:var(--white);box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;animation:slideIn .2s ease;z-index:401;overflow:hidden}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.sp-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border);background:#fafafa}.sp-header-left{display:flex;align-items:center;gap:12px}.sp-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--red) 0%,#9B2C2C 100%);color:var(--white);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sp-name{font-size:16px;font-weight:700;color:var(--navy)}.sp-role{font-size:12px;color:var(--text-soft);margin-top:2px}.sp-close{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--white);color:var(--text-soft);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.sp-close:hover{background:#fff5f5;border-color:#fed7d7;color:var(--red)}.sp-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.sp-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.sp-card-title{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}.sp-card-name{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:10px}.sp-card-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.sp-card-row:last-child{margin-bottom:0}.sp-label{font-size:12px;color:var(--text-soft)}.sp-value{font-size:12px;color:var(--text);font-weight:500}.sp-chip{font-size:11px;font-weight:700}.sp-manager-name{font-size:14px;font-weight:600;color:var(--text)}.sp-empty{font-size:13px;color:#cbd5e0;font-style:italic}.reminder-val{display:flex;align-items:center}.sp-reminder-card{border-color:#fed7d7;background:#fff5f5}.sp-note{width:100%;border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;font-family:inherit;color:var(--text);resize:none;outline:none;background:var(--white);box-sizing:border-box;margin-bottom:10px;transition:border .15s}.sp-note:focus{border-color:var(--red)}.sp-send-btn{width:100%;padding:10px;border-radius:6px;border:none;background:var(--red);color:var(--white);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.sp-send-btn:hover:not(:disabled){background:#9b2c2c}.sp-send-btn:disabled{opacity:.6;cursor:not-allowed}.sp-send-btn.sent{background:#10b981}@media (max-width: 1100px){.mis-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.mis-topbar,.mis-filters,.mis-table-wrap,.mis-stats{margin-left:16px;margin-right:16px}.mis-topbar{padding:16px}.mis-stats{padding:16px 16px 0}.side-panel{width:100%}.mis-table th:nth-child(6),.mis-table td:nth-child(6){display:none}}.emp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .15s ease}.emp-modal{background:var(--white);border-radius:12px;box-shadow:0 24px 64px #0000002e;width:100%;max-width:660px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .2s ease}@keyframes modalSlideIn{0%{transform:translateY(20px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.emp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 18px;border-bottom:1px solid var(--border);background:#fafafa;flex-shrink:0}.emp-modal-identity{display:flex;align-items:center;gap:14px}.emp-modal-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--red) 0%,#9B2C2C 100%);color:var(--white);font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.emp-modal-name{font-size:18px;font-weight:700;color:var(--navy);margin:0 0 4px}.emp-modal-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;color:var(--text-soft)}.emp-modal-dept,.emp-modal-mgr{color:var(--text-soft)}.emp-modal-close{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:var(--white);color:var(--text-soft);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.emp-modal-close:hover{background:#fff5f5;border-color:#fed7d7;color:var(--red)}.emp-modal-stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border);flex-shrink:0}.emp-modal-stat{padding:14px 16px;text-align:center;border-right:1px solid var(--border)}.emp-modal-stat:last-child{border-right:none}.emp-modal-stat-val{font-size:22px;font-weight:700;line-height:1;color:var(--navy);font-variant-numeric:tabular-nums}.emp-modal-stat-label{font-size:11px;color:var(--text-soft);font-weight:500;margin-top:3px;text-transform:uppercase;letter-spacing:.4px}.emp-modal-tabs{display:flex;gap:0;padding:0 24px;border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0}.emp-tab-btn{padding:12px 16px;border:none;border-bottom:2px solid transparent;background:none;font-size:13px;font-weight:500;color:var(--text-soft);cursor:pointer;transition:all .15s;white-space:nowrap;margin-bottom:-1px}.emp-tab-btn:hover{color:var(--navy)}.emp-tab-btn.active{color:var(--red);border-bottom-color:var(--red);font-weight:600}.emp-modal-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.emp-modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-soft);gap:12px;font-size:14px}.emp-modal-error{padding:16px;background:#fff5f5;border:1px solid #FED7D7;border-radius:var(--radius);color:var(--red);font-size:13px}.emp-modal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-soft);font-size:14px;gap:6px}.emp-project-card{border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;background:var(--white);transition:box-shadow .15s}.emp-project-card:hover{box-shadow:var(--shadow-md)}.emp-project-card-done{background:#fafafa;opacity:.85}.emp-project-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.emp-project-name-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.emp-project-name{font-size:14px;font-weight:600;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emp-project-badges{display:flex;gap:6px;flex-shrink:0}.emp-project-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.emp-project-meta-item{font-size:11px;color:var(--text-soft)}.emp-reminder-count{color:#e53e3e;font-weight:600}.emp-submitted-at{color:#10b981;font-weight:600}.emp-reminder-section{border-top:1px solid var(--border);padding-top:10px;margin-top:2px;display:flex;flex-direction:column;gap:8px}.emp-reminder-note{width:100%;border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:12px;font-family:inherit;color:var(--text);resize:none;outline:none;background:var(--white);box-sizing:border-box;transition:border .15s}.emp-reminder-note:focus{border-color:var(--red)}.emp-reminder-note:disabled{background:#f7fafc;color:var(--text-soft)}.emp-reminder-btn{align-self:flex-end;padding:8px 18px;border-radius:6px;border:none;background:var(--red);color:var(--white);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.emp-reminder-btn:hover:not(:disabled){background:#9b2c2c}.emp-reminder-btn:disabled{opacity:.6;cursor:not-allowed}.emp-reminder-btn.sent{background:#10b981}.emp-project-done-note{font-size:11px;color:#10b981;font-weight:500;border-top:1px solid #C6F6D5;padding-top:8px;margin-top:2px}.skeleton-line{background:linear-gradient(90deg,#e2e8f0 25%,#edf2f7,#e2e8f0 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:4px;display:block}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.mis-row{cursor:pointer}.mis-row:hover .emp-name{color:var(--red)}.mis-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.mis-modal{background:var(--white);border-radius:12px;box-shadow:0 20px 60px #0003;width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .2s ease}.mis-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.mis-modal-close{background:none;border:none;font-size:18px;color:var(--text-soft);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s}.mis-modal-close:hover{background:var(--bg);color:var(--text)}.mis-modal-body{padding:20px 24px;overflow-y:auto}.mis-modal-body .mis-table{font-size:12px}.mis-modal-body .mis-table th{font-size:10px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fafafa;--bg-2: #ffffff;--bg-3: #f5f5f5;--bg-4: #f0f0f0;--bg-5: #eeeeee;--border: #e0e0e0;--border-2: #d0d0d0;--text: #1a1a1a;--text-2: #4a4a4a;--text-3: #808080;--accent: #d32f2f;--accent-2: #e53935;--accent-dim: rgba(211,47,47,.12);--accent-dim2: rgba(211,47,47,.06);--green: #52c98a;--green-dim: rgba(82,201,138,.12);--red: #d32f2f;--red-dim: rgba(211,47,47,.12);--blue: #6aace8;--blue-dim: rgba(106,172,232,.12);--purple: #a87ee8;--purple-dim: rgba(168,126,232,.12);--orange: #e8924a;--orange-dim: rgba(232,146,74,.12);--teal: #4ac8c8;--teal-dim: rgba(74,200,200,.12);--radius-xs: 4px;--radius-sm: 7px;--radius: 11px;--radius-lg: 16px;--radius-xl: 22px;--font-display: "Georgia", "Trebuchet MS", serif;--font-body: "DM Sans", sans-serif;--sidebar-w: 248px;--t: .18s ease;--shadow: 0 4px 24px rgba(0,0,0,.08);--shadow-sm: 0 2px 8px rgba(0,0,0,.05)}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:2px}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg);flex-direction:column;gap:16px}.spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .65s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-brand{padding:26px 22px 18px;border-bottom:1px solid var(--border)}.sidebar-logo{display:flex;align-items:center;gap:10px;margin-bottom:2px}.sidebar-logo-mark{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:14px;font-weight:800;color:#fff;box-shadow:0 2px 8px #d32f2f33}.sidebar-brand-name{font-family:var(--font-display);font-size:17px;font-weight:900;letter-spacing:-.4px;color:var(--text)}.sidebar-brand-sub{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1.8px;margin-top:1px}.sidebar-nav{flex:1;padding:14px 10px;display:flex;flex-direction:column;gap:1px;overflow-y:auto}.sidebar-label{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:2px;padding:10px 12px 4px;margin-top:4px}.nav-link{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:var(--radius-sm);color:var(--text-2);text-decoration:none;font-size:13px;font-weight:400;transition:all var(--t);position:relative}.nav-link:hover{background:var(--bg-3);color:var(--text)}.nav-link.active{background:var(--accent-dim);color:var(--accent-2);font-weight:500}.nav-link .ni{font-size:14px;opacity:.6;flex-shrink:0}.nav-link.active .ni{opacity:1}.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.sidebar-footer{padding:12px 10px;border-top:1px solid var(--border)}.user-card{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:var(--radius-sm);background:var(--bg-3);cursor:default}.user-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.avatar-hr{background:var(--accent-dim);color:var(--accent)}.avatar-ap{background:var(--purple-dim);color:var(--purple)}.avatar-em{background:var(--blue-dim);color:var(--blue)}.avatar-sc{background:var(--teal-dim);color:var(--teal)}.avatar-ba,.avatar-ac,.avatar-an{background:var(--green-dim);color:var(--green)}.avatar-default{background:var(--bg-5);color:var(--text-3)}.user-info{flex:1;min-width:0}.user-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--text-2);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.logout-btn{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:14px;padding:3px;transition:color var(--t);border-radius:4px;line-height:1}.logout-btn:hover{color:var(--red)}.top-right-logout{position:absolute;top:24px;right:36px;background:var(--accent);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--t)}.top-right-logout:hover{background:var(--accent-2);transform:translateY(-1px)}.main-content{flex:1;overflow-y:auto;padding:32px 36px;background:var(--bg);position:relative}.page-header{margin-bottom:26px}.page-title{font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--text)}.page-subtitle{color:var(--text-2);font-size:13px;margin-top:3px}.page-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:22px}.stat-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;transition:border-color var(--t)}.stat-card:hover{border-color:var(--border-2)}.stat-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1.2px}.stat-value{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--text);margin-top:5px;line-height:1}.stat-sub{font-size:11px;color:var(--text-3);margin-top:4px}.c-accent{color:var(--accent)!important}.c-green{color:var(--green)!important}.c-red{color:var(--red)!important}.c-blue{color:var(--blue)!important}.c-purple{color:var(--purple)!important}.c-orange{color:var(--orange)!important}.c-teal{color:var(--teal)!important}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px}.card-sm{padding:14px 18px}.card-hover{transition:border-color var(--t);cursor:pointer}.card-hover:hover{border-color:var(--border-2)}.table-wrap{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}table{width:100%;border-collapse:collapse}thead th{background:var(--bg-3);padding:11px 16px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-3);border-bottom:1px solid var(--border)}tbody td{padding:12px 16px;font-size:13px;color:var(--text-2);border-bottom:1px solid var(--border)}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--t)}tbody tr:hover{background:var(--bg-3)}tbody tr.clickable{cursor:pointer}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;white-space:nowrap}.b-green{background:var(--green-dim);color:var(--green)}.b-red{background:var(--red-dim);color:var(--red)}.b-accent{background:var(--accent-dim);color:var(--accent-2)}.b-blue{background:var(--blue-dim);color:var(--blue)}.b-purple{background:var(--purple-dim);color:var(--purple)}.b-orange{background:var(--orange-dim);color:var(--orange)}.b-teal{background:var(--teal-dim);color:var(--teal)}.b-gray{background:var(--bg-4);color:var(--text-3)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all var(--t);text-decoration:none;white-space:nowrap;line-height:1.4}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-2);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border-2)}.btn-ghost:hover:not(:disabled){background:var(--bg-3);color:var(--text)}.btn-sm{padding:5px 11px;font-size:12px}.btn-lg{padding:11px 22px;font-size:14px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--text-3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 13px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:13.5px;transition:border-color var(--t);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-3)}.form-select option{background:var(--bg-3)}.form-textarea{resize:vertical;min-height:72px;line-height:1.6}.form-hint{font-size:11px;color:var(--text-3);margin-top:4px}.pbar-wrap{height:4px;background:var(--bg-5);border-radius:2px;overflow:hidden}.pbar-fill{height:100%;border-radius:2px;transition:width .5s ease}.pbar-accent{background:var(--accent)}.pbar-green{background:var(--green)}.pbar-blue{background:var(--blue)}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:9px 16px;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:13px;color:var(--text-3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--t)}.tab:hover{color:var(--text-2)}.tab.active{color:var(--accent-2);border-bottom-color:var(--accent)}.breadcrumb{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-3);margin-bottom:18px}.breadcrumb a{color:var(--text-3);text-decoration:none;transition:color var(--t)}.breadcrumb a:hover{color:var(--text-2)}.alert{padding:11px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:14px;border:1px solid transparent}.alert-error{background:var(--red-dim);color:var(--red);border-color:#e060604d}.alert-success{background:var(--green-dim);color:var(--green);border-color:#52c98a4d}.alert-info{background:var(--blue-dim);color:var(--blue);border-color:#6aace84d}.divider{height:1px;background:var(--border);margin:18px 0}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.empty{text-align:center;padding:56px 24px;color:var(--text-3)}.empty-icon{font-size:32px;margin-bottom:10px;opacity:.3}.empty-text{font-size:13.5px}.rating-group{display:flex;gap:5px}.rating-btn{flex:1;padding:6px 3px;border-radius:var(--radius-sm);background:var(--bg-3);border:1px solid var(--border);color:var(--text-3);font-size:10px;font-weight:700;cursor:pointer;transition:all var(--t);text-transform:uppercase;letter-spacing:.4px;text-align:center}.rating-btn:hover{border-color:var(--border-2);color:var(--text-2)}.rb-NI.sel{background:var(--red-dim);border-color:var(--red);color:var(--red)}.rb-EM.sel{background:var(--orange-dim);border-color:var(--orange);color:var(--orange)}.rb-SA.sel{background:var(--blue-dim);border-color:var(--blue);color:var(--blue)}.rb-MA.sel{background:var(--green-dim);border-color:var(--green);color:var(--green)}.rb-OU.sel{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-2)}.comp-section{margin-bottom:28px}.comp-section-title{font-family:var(--font-display);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--accent);margin-bottom:10px;padding-bottom:7px;border-bottom:1px solid var(--border)}.comp-row{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;transition:border-color var(--t)}.comp-row:hover{border-color:var(--border-2)}.comp-name{font-size:13.5px;font-weight:500;margin-bottom:8px}.comp-meta{font-size:11px;color:var(--text-3);margin-bottom:9px}.comp-descriptor{font-size:11px;color:var(--text-3);font-style:italic;padding:6px 10px;background:var(--bg-4);border-radius:var(--radius-sm);margin:7px 0;line-height:1.55}.sticky-bar{position:sticky;bottom:-30px;background:var(--bg-2);border-top:1px solid var(--border);padding:14px 36px;margin:0 -36px -1px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:20}.sticky-left{font-size:12px;color:var(--text-3)}.sticky-right{display:flex;gap:8px}.feedback-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;margin-bottom:10px;transition:border-color var(--t)}.feedback-card:hover{border-color:var(--border-2)}.feedback-card.due{border-left:3px solid var(--orange)}.feedback-card.submitted{border-left:3px solid var(--green)}.feedback-card.pending{border-left:3px solid var(--border-2)}.project-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:10px}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.project-name{font-weight:600;font-size:14px;color:var(--text);margin-bottom:3px}.project-meta{font-size:11px;color:var(--text-3)}.project-stats{display:flex;gap:16px;margin-top:12px}.project-stat{font-size:11px;color:var(--text-3)}.project-stat strong{color:var(--text-2);font-weight:500}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{font-family:var(--font-display);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-2)}.section-count{font-size:11px;color:var(--text-3)}.rating-chip{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;font-size:10px;font-weight:800;letter-spacing:.3px}.rc-NI{background:var(--red-dim);color:var(--red)}.rc-EM{background:var(--orange-dim);color:var(--orange)}.rc-SA{background:var(--blue-dim);color:var(--blue)}.rc-MA{background:var(--green-dim);color:var(--green)}.rc-OU{background:var(--accent-dim);color:var(--accent-2)}.rc-NA{background:var(--bg-4);color:var(--text-3)}.login-page{min-height:100vh;display:flex;background:var(--bg)}.login-left{flex:1;display:flex;flex-direction:column;justify-content:center;padding:60px;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 25% 55%,rgba(211,47,47,.07) 0%,transparent 60%);pointer-events:none}.login-right{width:420px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;padding:56px 44px;background:var(--bg-2);border-left:1px solid var(--border)}.login-brand{font-family:var(--font-display);font-size:48px;font-weight:900;letter-spacing:-1.6px;line-height:1.05;color:var(--text)}.login-brand em{color:var(--accent);font-style:normal}.login-tagline{font-size:15px;color:var(--text-2);margin-top:14px;max-width:380px;line-height:1.75}.login-features{margin-top:36px;display:flex;flex-direction:column;gap:18px}.lf-item{display:flex;align-items:flex-start;gap:13px}.lf-icon{width:34px;height:34px;border-radius:9px;background:var(--bg-3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;margin-top:1px}.lf-title{font-weight:500;font-size:13.5px;color:var(--text)}.lf-desc{font-size:12px;color:var(--text-3);line-height:1.5;margin-top:1px}.login-form-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:4px}.login-form-sub{font-size:13px;color:var(--text-3);margin-bottom:24px}.test-box{background:var(--accent-dim2);border:1px dashed var(--border-2);border-radius:var(--radius-sm);padding:11px 13px;margin-bottom:18px}.test-box-label{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}.test-row{display:flex;align-items:center;gap:8px;margin-bottom:5px}.test-row:last-child{margin-bottom:0}.test-email{font-size:11.5px;color:var(--text-2);font-family:monospace;flex:1}.use-btn{background:none;border:none;cursor:pointer;font-size:10px;color:var(--accent);padding:1px 4px;transition:opacity var(--t);font-family:var(--font-body)}.use-btn:hover{opacity:.6}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeUp .28s ease forwards}.text-muted{color:var(--text-3)}.text-sm{font-size:12px}.fw-500{font-weight:500}.fw-600{font-weight:600}.gap-8{gap:8px}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}
