.roadmap-gantt-wrapper{background:#fff;color:#1e293b;position:relative}.roadmap-gantt-wrapper [class*=Tooltip],.roadmap-gantt-wrapper [class*=tooltip]{z-index:100!important;pointer-events:none}.roadmap-gantt-wrapper [class*=barProgressHandle],.roadmap-gantt-wrapper [class*=barWrapper],.roadmap-gantt-wrapper g[class*=bar]{cursor:pointer}.roadmap-gantt-wrapper,.roadmap-gantt-wrapper>*,.roadmap-gantt-wrapper>*>*,.roadmap-gantt-wrapper>*>*>*{background-color:transparent}.roadmap-gantt-wrapper svg,.roadmap-gantt-wrapper>div:first-child{background:#fff!important}.roadmap-gantt-wrapper svg>g>rect:not([style*=fill]),.roadmap-gantt-wrapper svg>rect{fill:#fff!important}.roadmap-gantt-wrapper svg g[class*=calendar] rect{fill:#f8fafc!important}.roadmap-gantt-wrapper svg g[class*=calendar] text{fill:#475569!important}.roadmap-gantt-wrapper svg line{stroke:#e2e8f0!important}.roadmap-gantt-wrapper text{fill:#1e293b}.roadmap-gantt-wrapper svg g[class*=gridRow] rect{fill:#fff!important}.roadmap-gantt-wrapper svg g[class*=gridRowLine] line{stroke:#f1f5f9!important}:root{--brand:#4361ee;--surface:#f1f5f9;--body-bg:#f1f5f9;--text-default:#0f172a;--topbar-bg:#fff;--topbar-border:#e2e8f0;--card-shadow:0 1px 4px rgba(0,0,0,.06),0 6px 20px rgba(0,0,0,.05);--bs-font-sans-serif:"Playpen Sans Thai","Segoe UI",sans-serif;--bs-body-font-family:"Playpen Sans Thai","Segoe UI",sans-serif;--sidebar-w:240px;--sidebar-w-collapsed:64px}.app-shell{display:flex;min-height:100vh}.app-sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#1d3461,#0f172a);color:hsla(0,0%,100%,.85);display:flex;flex-direction:column;flex-shrink:0;position:-webkit-sticky;position:sticky;top:0;height:100vh;box-shadow:2px 0 16px rgba(0,0,0,.18);z-index:100;transition:width .2s ease;overflow-x:hidden}.app-shell.collapsed .app-sidebar{width:var(--sidebar-w-collapsed)}.app-shell.collapsed .app-brand-text,.app-shell.collapsed .app-nav-lb,.app-shell.collapsed .app-user-meta{display:none}.app-shell.collapsed .app-user-card{justify-content:center;padding:.5rem}.app-brand{gap:.65rem;padding:1rem 1.1rem;border-bottom:1px solid hsla(0,0%,100%,.08)}.app-brand,.app-brand-icon{display:flex;align-items:center}.app-brand-icon{width:36px;height:36px;background:linear-gradient(135deg,#4361ee,#7209b7);border-radius:.55rem;justify-content:center;font-size:1.1rem;flex-shrink:0}.app-brand-text{min-width:0}.app-brand-name{font-size:.95rem;font-weight:800;color:#fff;line-height:1.1}.app-brand-sub{font-size:.65rem;color:hsla(0,0%,100%,.45);white-space:nowrap}.app-nav{flex:1 1;padding:.75rem .5rem;display:flex;flex-direction:column;gap:.15rem;overflow-y:auto}.app-nav-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .75rem;border-radius:.5rem;color:hsla(0,0%,100%,.7);text-decoration:none;font-size:.85rem;font-weight:500;white-space:nowrap;transition:background .15s,color .15s}.app-nav-item:hover{background:hsla(0,0%,100%,.07);color:#fff}.app-nav-item.active{background:linear-gradient(135deg,rgba(67,97,238,.3),rgba(114,9,183,.25));color:#fff;font-weight:700;box-shadow:inset 3px 0 0 #4361ee}.app-nav-ic{font-size:1.05rem;width:24px;text-align:center;flex-shrink:0}.app-nav-lb{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis}.app-sidebar-footer{padding:.65rem .5rem .75rem;border-top:1px solid hsla(0,0%,100%,.08);display:flex;flex-direction:column;gap:.35rem;position:relative}.app-user-card{display:flex;align-items:center;gap:.6rem;padding:.55rem .65rem;background:hsla(0,0%,100%,.05);border-radius:.5rem;margin-bottom:.25rem}.app-user-avatar{width:32px;height:32px;background:linear-gradient(135deg,#4361ee,#7209b7);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex-shrink:0}.app-user-meta{min-width:0;flex:1 1}.app-user-name{font-size:.78rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-user-tags{display:flex;gap:.25rem;margin-top:.1rem;flex-wrap:wrap}.app-user-dept{background:hsla(0,0%,100%,.15);color:hsla(0,0%,100%,.85);font-size:.6rem}.app-user-dept,.app-user-role{padding:.05rem .35rem;border-radius:.25rem;font-weight:700}.app-user-role{font-size:.58rem;text-transform:uppercase}.app-user-role.manager{background:#fbbf24;color:#1e293b}.app-user-role.officer{background:#94a3b8;color:#1e293b}.app-logout{display:flex;align-items:center;gap:.7rem;padding:.55rem .75rem;background:transparent;border:1px solid hsla(0,91%,71%,.4);color:#fca5a5;border-radius:.5rem;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;font-family:inherit}.app-logout:hover{background:hsla(0,91%,71%,.15);color:#fee2e2}.app-collapse-toggle{position:absolute;top:-14px;right:-14px;width:28px;height:28px;background:#1d3461;border:2px solid hsla(0,0%,100%,.15);color:hsla(0,0%,100%,.7);border-radius:50%;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;z-index:10}.app-collapse-toggle:hover{color:#fff;background:#2a4373}.app-main{flex:1 1;min-width:0;display:flex;flex-direction:column}@media (max-width:768px){.app-sidebar{width:var(--sidebar-w-collapsed)}.app-shell .app-brand-text,.app-shell .app-nav-lb,.app-shell .app-user-meta{display:none}}.page-topbar{display:flex;align-items:center;gap:1rem;padding:.7rem 1.5rem;background:#fff;border-bottom:1px solid #e2e8f0;position:-webkit-sticky;position:sticky;top:0;z-index:50;box-shadow:0 1px 4px rgba(0,0,0,.04)}.page-title{font-size:1rem;font-weight:700;color:#0f172a;display:flex;align-items:baseline;gap:.5rem;white-space:nowrap}.page-title small{font-size:.7rem;font-weight:400;color:#94a3b8}.page-topbar-spacer{flex:1 1}.page-topbar-countdown{flex:1 1;display:flex;align-items:center;gap:.55rem;min-width:0;font-size:.72rem;color:#64748b;font-weight:600;white-space:nowrap}.page-topbar-countdown-bar{flex:1 1;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden;max-width:220px}.page-topbar-countdown-fill{height:100%;background:#fbbf24;border-radius:2px;transition:width 1s linear}.page-topbar-btn{border:1px solid #cbd5e1;background:#fff;color:#475569;border-radius:.5rem;padding:.4rem .9rem;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;font-family:inherit;transition:background .15s,border-color .15s,color .15s}.page-topbar-btn:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8;color:#0f172a}.page-topbar-btn:disabled{opacity:.55;cursor:wait}.page-topbar-btn.yellow{border-color:#fbbf24;color:#d97706;background:#fffbeb}.page-topbar-select{border:1px solid #cbd5e1;background:#fff;border-radius:.5rem;padding:.35rem .65rem;font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;outline:none}*{box-sizing:border-box}*,body{font-family:Playpen Sans Thai,Segoe UI,sans-serif!important}body{background:var(--surface);color:#1e293b;font-size:.9rem}.it-nav{background:linear-gradient(135deg,#0f172a,#1d3461);padding:.6rem 1.75rem;gap:1rem;box-shadow:0 2px 16px rgba(0,0,0,.25);position:-webkit-sticky;position:sticky;top:0;z-index:100}.it-nav,.it-nav .brand{display:flex;align-items:center}.it-nav .brand{font-size:1rem;font-weight:700;color:#fff;gap:.5rem;white-space:nowrap}.it-nav .brand-icon{background:linear-gradient(135deg,#4361ee,#7209b7);width:28px;height:28px;border-radius:.4rem;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}.it-nav .brand-sub{color:hsla(0,0%,100%,.45);font-size:.7rem;font-weight:400;margin-left:.25rem}.nav-countdown{flex:1 1;display:flex;align-items:center;gap:.6rem;min-width:0}.nav-countdown-bar{flex:1 1;height:4px;background:hsla(0,0%,100%,.15);border-radius:2px;overflow:hidden;max-width:200px}.nav-countdown-fill{height:100%;background:#fbbf24;border-radius:2px;transition:width 1s linear}.nav-countdown-text{color:hsla(0,0%,100%,.55);font-size:.72rem;white-space:nowrap}.it-nav .btn-nav{border:1px solid hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.8);background:hsla(0,0%,100%,.07);border-radius:.4rem;padding:.28rem .7rem;font-size:.75rem;cursor:pointer;transition:background .15s;white-space:nowrap}.it-nav .btn-nav:hover{background:hsla(0,0%,100%,.16);color:#fff}.it-nav .btn-nav.yellow{border-color:#fbbf24;color:#fbbf24}.stat-card{background:#fff;border-radius:.875rem;box-shadow:var(--card-shadow);padding:.85rem 1rem;display:flex;flex-direction:column;align-items:flex-start;gap:.4rem;border:none;border-top:3px solid #e2e8f0;transition:transform .15s,box-shadow .15s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.08),0 12px 28px rgba(0,0,0,.08)}.stat-icon{width:32px;height:32px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.stat-val{font-size:1.6rem;font-weight:700;line-height:1.1;color:#1e293b}.stat-label{font-size:.68rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.it-tabs{display:flex;gap:.25rem;flex-wrap:wrap;border-bottom:2px solid #e2e8f0;background:#fff;border-radius:1rem 1rem 0 0;padding:.6rem .75rem 0}.it-tabs .tab-btn{background:none;cursor:pointer;padding:.45rem .85rem;font-size:.8rem;font-weight:500;color:#64748b;border-radius:.5rem .5rem 0 0;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,background .15s;white-space:nowrap}.it-tabs .tab-btn.active,.it-tabs .tab-btn:hover{color:var(--brand);background:rgba(67,97,238,.06)}.it-tabs .tab-btn.active{font-weight:600;border-bottom-color:var(--brand)}.it-tab-content{background:#fff;border-radius:0 0 1rem 1rem;box-shadow:var(--card-shadow);padding:1.25rem;margin-bottom:2rem}.it-tab-pane{display:none}.it-tab-pane.active{display:block}.card{border:none;border-radius:.875rem;box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 12px rgba(0,0,0,.04)}.card-header{background:#f8fafc;border-bottom:1px solid #e8ecf0;border-radius:.875rem .875rem 0 0!important;padding:.7rem 1.1rem;font-size:.875rem}.table{font-size:.84rem}.table thead th{background:#f8fafc;color:#64748b;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e2e8f0}.table-hover tbody tr:hover td{background:rgba(67,97,238,.04)}.table-responsive-wrap{overflow-x:auto}.action-list{padding:.25rem 0}.action-row{padding:.7rem 1rem;border-bottom:1px solid #f1f5f9;border-left:3px solid #e2e8f0}.action-row:last-child{border-bottom:none}.action-row-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.action-icon{font-size:1rem;flex-shrink:0}.action-msg{font-size:.82rem;color:#374151;flex:1 1;min-width:0}.action-tasks{padding-left:1.75rem;margin-top:.4rem}.action-task-row{font-size:.79rem;padding:.2rem 0;display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem;border-bottom:1px dotted #f1f5f9}.action-task-row:last-of-type{border-bottom:none}.action-task-link{font-weight:600;text-decoration:none;color:#1e293b}.action-task-link:hover{color:var(--brand);text-decoration:underline}.action-task-proj{color:#94a3b8;font-size:.72rem;width:100%}.action-more-btn{background:none;border:none;color:var(--brand);font-size:.75rem;cursor:pointer;padding:.2rem 0;margin-top:.2rem}.action-more-btn:hover{text-decoration:underline}.sub-btn{background:none;border:1px solid #e2e8f0;border-radius:.4rem;padding:.3rem .75rem;font-size:.78rem;color:#64748b;cursor:pointer;transition:all .15s}.sub-btn:hover{background:rgba(67,97,238,.06);color:var(--brand);border-color:var(--brand)}.sub-btn.active{background:var(--brand);color:#fff;border-color:var(--brand);font-weight:600}.alert{border-radius:.75rem;font-size:.85rem}.date-header{font-size:.82rem;color:#94a3b8;font-weight:500;margin-bottom:1.25rem;display:flex;align-items:center;gap:.4rem}@media print{.no-print{display:none!important}}@media (max-width:768px){.brand-sub{display:none}.nav-countdown-bar{max-width:80px}.container-fluid{padding-left:.75rem!important;padding-right:.75rem!important}.action-tasks{padding-left:.75rem}table[style*="table-layout:fixed"]{table-layout:auto!important;min-width:560px}}.line-clamp-1{-webkit-line-clamp:1}.line-clamp-1,.line-clamp-2{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2}@media (max-width:768px){.it-nav{padding:.5rem 1rem;gap:.6rem}.it-tabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.it-tabs::-webkit-scrollbar{display:none}.it-tabs .tab-btn{flex-shrink:0}:root{--sidebar-w:var(--sidebar-w-collapsed)}.app-brand-text,.app-nav-lb,.app-user-meta{display:none}.app-user-card{justify-content:center;padding:.5rem}.app-collapse-toggle{display:none}.page-topbar{flex-wrap:wrap;gap:.5rem;padding:.6rem .85rem}.page-title{font-size:.9rem}.page-title small{display:none}.page-topbar-countdown{order:99;width:100%;flex-basis:100%;font-size:.65rem}.page-topbar-countdown-bar{max-width:none}.page-topbar-btn{padding:.35rem .65rem;font-size:.72rem}.page-topbar-select{font-size:.72rem;padding:.35rem .55rem;max-width:140px}.container-fluid{padding-left:.85rem!important;padding-right:.85rem!important}}@media (max-width:480px){.page-topbar{padding:.5rem .65rem}.page-title{font-size:.82rem}.page-topbar-btn{padding:.3rem .55rem;font-size:.68rem}.page-topbar-btn span{display:none}.card-body{padding:.75rem .85rem}.container-fluid{padding-left:.55rem!important;padding-right:.55rem!important}}