:root{--ksu:#075c3b;--ksu-2:#0f7a50;--ksu-soft:#e9f4ef;--line:#d9e6df;--dark:#203128;--muted:#6d7972;--bg:#f4f7f5;--sidebar:#eef3ef}*{box-sizing:border-box}body{margin:0;background:var(--bg);font-family:"Segoe UI",Roboto,Arial,sans-serif;color:#24342b}.app-shell{display:flex;min-height:100vh}.sidebar{width:264px;background:#f0f4f1;border-right:1px solid var(--line);position:fixed;top:0;left:0;bottom:0;z-index:1030;transition:.2s}.sidebar.collapsed{width:70px}.brand{height:64px;display:flex;align-items:center;gap:12px;padding:0 18px;border-bottom:1px solid var(--line);color:var(--ksu)}.brand img{width:34px;height:34px;object-fit:contain;border-radius:50%}.brand small{display:block;font-size:11px;color:var(--muted);letter-spacing:.03em}.sidebar.collapsed .brand div,.sidebar.collapsed .side-nav span,.sidebar.collapsed .brand img{display:none}.side-nav{padding:14px 0}.side-nav a{display:flex;align-items:center;gap:14px;padding:14px 20px;text-decoration:none;color:#4d5b53;font-weight:500;transition:.15s;border-left:4px solid transparent}.side-nav a:hover{background:#e4eee8;color:var(--ksu)}.side-nav a.active{background:var(--ksu);color:white;border-left-color:#a9dcc7}.side-nav i{font-size:20px;width:22px;text-align:center}.main-panel{margin-left:264px;width:calc(100% - 264px);transition:.2s}.sidebar.collapsed+.main-panel{margin-left:70px;width:calc(100% - 70px)}.topbar{height:64px;background:#fff;border-bottom:1px solid var(--line);padding:0 20px;position:sticky;top:0;z-index:1020}.topbar-title h5{font-weight:700;color:#1d382a}.icon-btn{position:relative;width:42px;height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;border:0;color:#40554a;background:transparent}.icon-btn:hover{background:var(--ksu-soft);color:var(--ksu)}.notif-dot{position:absolute;right:2px;top:0;background:#d83232;color:#fff;border-radius:20px;font-size:10px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center}.profile-btn{display:flex;align-items:center;gap:8px;border:0;background:#f7faf8;border-radius:20px;padding:6px 12px}.profile-btn img{width:32px;height:32px;border-radius:50%;object-fit:contain}.content-wrap{padding:20px}.page-tabs{display:flex;gap:26px;border-bottom:1px solid var(--line);background:#fff;margin:-20px -20px 18px;padding:0 22px}.page-tabs a{padding:18px 0 14px;color:#4d5b53;text-decoration:none;font-weight:600;border-bottom:3px solid transparent}.page-tabs a.active{color:var(--ksu);border-color:var(--ksu)}.card-soft{border:1px solid var(--line);border-radius:18px;box-shadow:0 10px 30px rgba(29,56,42,.05);background:#fff}.stat-card{padding:18px;border-radius:18px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;gap:14px}.stat-card .icon{width:52px;height:52px;border-radius:16px;background:var(--ksu-soft);color:var(--ksu);display:flex;align-items:center;justify-content:center;font-size:26px}.stat-card h2{font-weight:800;margin:0;color:#203128}.btn-ksu{background:var(--ksu);color:white;border-color:var(--ksu);border-radius:10px;padding:.55rem 1rem}.btn-ksu:hover{background:#06492f;color:white}.btn-outline-ksu{border-color:var(--ksu);color:var(--ksu);border-radius:10px}.btn-outline-ksu:hover{background:var(--ksu);color:white}.soft-modal{border:0;border-radius:14px;box-shadow:0 15px 70px rgba(0,0,0,.25)}.soft-modal .modal-header{border:0;padding:22px 24px 8px}.soft-modal .modal-body{padding:16px 24px}.soft-modal .modal-footer{border:0;padding:12px 24px 24px}.form-control,.form-select{border-radius:10px;border-color:#dce7e1;min-height:44px}.program-card,.institute-card,.level-card{cursor:pointer;border:1px solid var(--line);border-radius:18px;background:#fff;transition:.15s;height:100%}.program-card:hover,.institute-card:hover,.level-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(7,92,59,.09)}.program-card .arrow,.institute-card .arrow{width:38px;height:38px;border-radius:12px;background:#f4faf7;color:var(--ksu);display:flex;align-items:center;justify-content:center}.badge-soft{background:var(--ksu-soft);color:var(--ksu);border-radius:30px;padding:.35rem .7rem}.badge-status{border-radius:30px;padding:.35rem .65rem;font-weight:700}.status-pending{background:#fff4d6;color:#8a6300}.status-approved{background:#dff5e8;color:#0e6b3c}.status-revision{background:#ffe3c7;color:#9d4d00}.status-rejected{background:#ffe0e0;color:#a72020}.status-submitted,.status-reviewed{background:#dcecff;color:#184f90}.instrument-toolbar{background:white;border:1px solid var(--line);border-radius:16px;padding:12px 14px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px}.instrument-tree{font-size:15px}.tree-node{position:relative;background:white;border:1px solid var(--line);border-radius:10px;margin:8px 0;padding:0;overflow:hidden}.tree-node.area{background:#d9e9e0}.tree-node.parameter{margin-left:24px;background:#e5f0ea}.tree-node.section{margin-left:48px;background:#ecf5f0}.tree-node.indicator{margin-left:72px;background:#fff}.tree-node .node-head{display:flex;align-items:center;gap:10px;min-height:46px;padding:10px 14px}.tree-node .node-title{flex:1}.tree-node .node-actions{display:flex;align-items:center;gap:6px}.tree-children{padding:0 0 8px}.tree-children.d-none{display:none}.tree-line{position:absolute;left:18px;top:44px;bottom:0;border-left:2px solid #6aad91}.indicator-label{color:#34443b;font-weight:700;margin-right:6px}.evidence-text{font-size:13px;color:#636f68}.breadcrumb-soft{display:flex;align-items:center;gap:8px;color:#61706a;margin-bottom:16px}.breadcrumb-soft a{color:var(--ksu);text-decoration:none}.task-row{background:white;border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:12px}.progress{height:10px;border-radius:20px}.drop-zone{border:2px dashed #b4c9bd;background:#f9fcfa;border-radius:18px;padding:24px;text-align:center;color:#607269;cursor:pointer}.drop-zone.dragover{background:#e8f5ee;border-color:var(--ksu)}.document-tile{border:1px solid var(--line);border-radius:16px;background:#fff;padding:14px;position:relative}.context-menu{position:absolute;background:#fff;border:1px solid var(--line);box-shadow:0 12px 40px rgba(0,0,0,.12);border-radius:12px;z-index:2000;min-width:210px;overflow:hidden;display:none}.context-menu button{width:100%;border:0;background:white;text-align:left;padding:10px 14px}.context-menu button:hover{background:var(--ksu-soft)}.preview-layout{display:grid;grid-template-columns:1fr 320px;gap:14px}.preview-frame{height:72vh;border:1px solid var(--line);border-radius:14px;background:#f6f8f6;overflow:hidden}.preview-frame iframe,.preview-frame img{width:100%;height:100%;object-fit:contain;border:0}.comment-box{max-height:280px;overflow:auto}.comment-item{border-left:3px solid var(--ksu);background:#f7fbf8;border-radius:8px;padding:10px;margin-bottom:8px}.rating-star{font-size:22px;color:#d4a208;cursor:pointer}.table>tbody>tr{vertical-align:middle}.notif-menu{width:330px;max-height:420px;overflow:auto}.login-page{min-height:100vh;background:linear-gradient(135deg,#06492f,#0f7a50);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:980px;background:#fff;border-radius:26px;overflow:hidden;box-shadow:0 30px 100px rgba(0,0,0,.3);display:grid;grid-template-columns:1fr 1.05fr}.login-brand{background:linear-gradient(180deg,rgba(7,92,59,.94),rgba(7,92,59,.76)),url('../img/login-bg.svg');background-size:cover;color:#fff;padding:44px;display:flex;flex-direction:column;justify-content:center}.login-brand img{width:92px;height:92px;object-fit:contain;background:rgba(255,255,255,.94);border-radius:50%;padding:8px;margin-bottom:22px}.login-form{padding:44px}.code-pill{font-family:ui-monospace,Consolas,monospace;background:#f1f4f2;border-radius:8px;padding:2px 8px}.print-header{display:none}@media(max-width:992px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-panel,.sidebar.collapsed+.main-panel{margin-left:0;width:100%}.preview-layout{grid-template-columns:1fr}.login-card{grid-template-columns:1fr}.login-brand{display:none}}@media print{.sidebar,.topbar,.btn,.no-print,.page-tabs{display:none!important}.main-panel{margin-left:0!important;width:100%!important}.content-wrap{padding:0}.card-soft{box-shadow:none;border:0}.print-header{display:block;text-align:center;margin-bottom:20px}}
.indicator-documents{margin-left:72px;background:#fbfdfb;border-left:3px solid #b7d6c5;border-radius:12px;padding:10px 10px 12px}.inline-doc-empty{color:#718076;background:#f3f8f5;border:1px dashed #bdd4c6;border-radius:12px;padding:12px;margin:0 6px 8px}.inline-doc-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;box-shadow:0 8px 20px rgba(7,92,59,.04);height:100%}.doc-icon{width:42px;height:42px;border-radius:12px;background:var(--ksu-soft);display:flex;align-items:center;justify-content:center;color:var(--ksu);font-size:24px}.btn-group-sm>.btn{border-radius:8px!important}.table .btn-group{flex-wrap:wrap;justify-content:end;gap:4px}.table .btn-group .btn{margin-left:0!important}.tree-node .dropdown-menu{z-index:2000}

/* v3 tree alignment fix: keeps each parameter/section/indicator row inside the same tree flow. */
.instrument-tree,
.instrument-tree * { box-sizing: border-box; }
.instrument-tree { width: 100%; overflow-x: hidden; }
.instrument-tree .node-title { min-width: 0; overflow-wrap: anywhere; }
.task-area-tree > .tree-node.parameter,
.task-area-tree .task-parameter { margin-left: 24px; margin-right: 0; width: calc(100% - 24px); }
.task-area-tree .parameter-children { margin-left: 0; width: 100%; clear: both; }
.task-area-tree .task-section { margin-left: 48px; width: calc(100% - 48px); }
.task-area-tree .section-children { margin-left: 0; width: 100%; clear: both; }
.task-area-tree .task-indicator { margin-left: 72px; width: calc(100% - 72px); }
.task-area-tree .indicator-documents { margin-left: 72px; width: calc(100% - 72px); }
.inline-doc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 10px; }
.min-w-0 { min-width: 0; }
@media(max-width: 768px){
  .task-area-tree .task-parameter { margin-left: 8px; width: calc(100% - 8px); }
  .task-area-tree .task-section { margin-left: 16px; width: calc(100% - 16px); }
  .task-area-tree .task-indicator,
  .task-area-tree .indicator-documents { margin-left: 24px; width: calc(100% - 24px); }
}

/* v5 accreditation-area management view */
.area-management-panel .assignment-box,
.area-overview-row .assignment-box{background:#f8fcfa;border:1px solid var(--line);border-radius:14px;padding:12px;min-height:76px}.assignment-box.compact{min-height:64px;padding:10px}.assignment-label{text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:800;color:var(--muted);margin-bottom:5px}.survey-area-tree .doc-count{display:inline-flex;align-items:center;gap:4px;color:var(--ksu);font-weight:700;font-size:13px;background:var(--ksu-soft);border-radius:20px;padding:4px 8px}.survey-area-tree .indicator-documents{margin-top:-4px;margin-bottom:10px}.area-overview-row .badge-soft{display:inline-flex;align-items:center;gap:5px}.area-overview-row h5{font-weight:800}.area-management-panel h4{font-weight:800}

/* v9 mobile responsive navigation and topbar fix */
html, body { max-width: 100%; overflow-x: hidden; }
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(15,31,24,.48);z-index:1025;backdrop-filter:blur(1px)}
body.sidebar-mobile-open{overflow:hidden;touch-action:none}
body.sidebar-mobile-open .sidebar-backdrop{display:block}
.topbar-title{min-width:0;line-height:1.1}.topbar-title h5{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand{min-width:0}.brand-text{min-width:0}.brand-text b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-close{margin-left:auto;flex:0 0 auto}.main-panel{min-width:0}.content-wrap{min-width:0}.dropdown-menu{max-width:calc(100vw - 24px)}

@media(max-width: 992px){
  .app-shell{display:block;min-height:100vh;width:100%}
  .sidebar{width:min(84vw,320px);max-width:320px;transform:translateX(-105%);box-shadow:none;z-index:1035;will-change:transform;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .sidebar.open{transform:translateX(0);box-shadow:12px 0 34px rgba(0,0,0,.18)}
  .sidebar.collapsed{width:min(84vw,320px)}
  .sidebar.collapsed .brand div,.sidebar.collapsed .side-nav span,.sidebar.collapsed .brand img{display:block}
  .brand{height:60px;padding:0 14px;gap:10px}.brand img{width:32px;height:32px}.brand small{font-size:10px}
  .side-nav{padding:8px 0 14px}.side-nav a{padding:13px 18px;font-size:15px}.side-nav i{font-size:19px}
  .main-panel,.sidebar.collapsed+.main-panel{margin-left:0!important;width:100%!important;max-width:100%;position:relative;z-index:1}
  .topbar{height:58px;padding:0 10px;gap:8px;position:sticky;top:0;z-index:1015;width:100%;max-width:100vw}
  .topbar .icon-btn{width:38px;height:38px;border-radius:10px;flex:0 0 auto}.topbar .ms-auto{gap:4px!important;min-width:0}
  .topbar-title{flex:1 1 auto;min-width:0}.topbar-title .small{font-size:10px;display:block}.topbar-title h5{font-size:16px;max-width:100%}
  .profile-btn{padding:4px 6px;border-radius:16px;gap:0;flex:0 0 auto}.profile-btn img{width:30px;height:30px}.profile-btn span{display:none}
  .notif-menu{width:calc(100vw - 24px);max-width:330px}
  .content-wrap{padding:12px;overflow-x:hidden}.page-tabs{margin:-12px -12px 12px;padding:0 14px;gap:18px;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.page-tabs::-webkit-scrollbar{height:4px}
  .instrument-toolbar{flex-direction:column;align-items:stretch}.instrument-toolbar .btn,.instrument-toolbar .btn-group{width:100%}
  .card-soft,.stat-card,.program-card,.institute-card,.level-card{border-radius:14px}
  .table-responsive,.dataTables_wrapper{width:100%;overflow-x:auto}.dataTables_wrapper .row{row-gap:8px}.dataTables_filter,.dataTables_length{text-align:left!important}
  .modal-dialog{margin:.75rem;max-width:calc(100vw - 1.5rem)}.soft-modal{border-radius:16px}.soft-modal .modal-header{padding:18px 18px 8px}.soft-modal .modal-body{padding:12px 18px}.soft-modal .modal-footer{padding:12px 18px 18px}
  .preview-frame{height:62vh}.preview-layout{grid-template-columns:1fr}.area-overview-row .d-flex,.area-management-panel .d-flex{flex-wrap:wrap;gap:8px}.area-overview-row .btn,.area-management-panel .btn{white-space:normal}
}

@media(max-width: 576px){
  .sidebar{width:86vw}.topbar{height:56px;padding:0 8px}.topbar-title h5{font-size:15px}.topbar-title .small{font-size:9px}.topbar .icon-btn{width:35px;height:35px}.profile-btn img{width:28px;height:28px}
  .content-wrap{padding:10px}.btn-ksu,.btn-outline-ksu{padding:.5rem .75rem}.stat-card{padding:14px}.stat-card .icon{width:44px;height:44px;font-size:22px}.stat-card h2{font-size:24px}
  .tree-node .node-head{padding:9px 10px;gap:6px;align-items:flex-start}.tree-node .node-actions{gap:3px;flex-wrap:wrap;justify-content:flex-end}.tree-node.parameter{margin-left:8px}.tree-node.section{margin-left:16px}.tree-node.indicator{margin-left:24px}.indicator-documents{margin-left:24px!important;width:calc(100% - 24px)!important}
  .inline-doc-grid{grid-template-columns:1fr}.document-tile{padding:12px}.drop-zone{padding:18px}.notif-dot{right:-2px;top:-2px}
  .row.g-3,.row.g-4{--bs-gutter-x:.75rem;--bs-gutter-y:.75rem}
}

/* v10 scoped workflow, messages, reports, and tasks */
.message-card{border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px;margin-bottom:10px}.message-card.unread{border-left:4px solid var(--ksu);background:#f5fbf7}.message-tabs .nav-link{color:#40554a;font-weight:600}.message-tabs .nav-link.active{color:var(--ksu);border-color:var(--line) var(--line) #fff}.notif-unread{background:#f4fbf7;border-left:3px solid var(--ksu)}.task-group-title{font-weight:800;color:var(--ksu);background:#e8f3ee;border:1px solid var(--line);border-radius:14px;padding:12px 16px;margin-bottom:10px;display:flex;align-items:center;gap:8px}.task-level-title{font-weight:700;color:#24342b;padding:8px 6px;margin:8px 0 6px;display:flex;align-items:center;gap:8px}.select2-container{max-width:100%}.select2-dropdown{z-index:3000}.modal .select2-container--bootstrap-5 .select2-selection{min-height:44px;border-radius:10px;border-color:#dce7e1}.modal .select2-container--open{z-index:3050}
@media(max-width:576px){.message-card{font-size:14px}.task-group-title{padding:10px 12px}.task-level-title{font-size:14px}.modal .select2-container{width:100%!important}}

/* v11: visible parameter/indicator comments and shared-document permission indicators */
.icon-btn .mini-count{position:absolute;right:0;top:0;background:#d83232;color:#fff;border-radius:999px;font-size:10px;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;line-height:1}.inline-comment-thread{margin:0 12px 12px 56px;border-left:3px solid var(--ksu);background:#f8fcfa;border-radius:12px;padding:8px 10px}.tree-node.indicator .inline-comment-thread{margin-left:14px}.inline-comment-item{background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 10px;margin-bottom:6px;font-size:13px}.inline-comment-item:last-child{margin-bottom:0}.badge-soft i{margin-right:4px}@media(max-width:768px){.inline-comment-thread{margin-left:10px;margin-right:10px}.tree-node.indicator .inline-comment-thread{margin-left:10px}.node-actions{flex-wrap:wrap}}

/* v12: comments are opened and managed in a modal instead of rendering inline under parameters/indicators */
.comment-modal-list{max-height:340px;overflow:auto;border:1px solid var(--line);border-radius:14px;background:#f8fcfa;padding:10px}
.comment-modal-item{background:#fff;border:1px solid var(--line);border-left:4px solid var(--ksu);border-radius:12px;padding:10px 12px;margin-bottom:8px;font-size:14px}
.comment-modal-item:last-child{margin-bottom:0}.comment-empty{border:1px dashed #bdd4c6;border-radius:12px;color:#718076;background:#fff;padding:18px;text-align:center}.comment-target-label{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-modal-list::-webkit-scrollbar{width:8px}.comment-modal-list::-webkit-scrollbar-thumb{background:#c8d8cf;border-radius:8px}

/* v13 task-scope controls */
.task-indicator.is-view-only-task { opacity: .92; }
.task-indicator.is-view-only-task .node-title { color: #3f4f4a; }
.task-scope-label { color: var(--ksu-green, #006b3f); }

/* v14: show exact parameter/indicator task assignments and avoid implying that all task-force members are assigned to every indicator */
.assignment-subnote{font-size:12px;font-weight:600;color:#6d7972;margin-top:4px;display:inline-block}
.assignment-chip-wrap{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-top:5px}
.assignment-chip{display:inline-flex;align-items:center;gap:4px;background:#eef8f2;color:#075c3b;border:1px solid #cfe7da;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:700;line-height:1.3}
.current-assignment-box{background:#f8fcfa;border:1px solid var(--line);border-radius:12px;padding:10px}
.current-assignment-list{display:flex;gap:6px;flex-wrap:wrap;align-items:center;min-height:24px}
.task-indicator.is-view-only-task .assignment-chip{background:#f7faf8;color:#647269;border-color:#dce7e1}
@media(max-width:576px){.assignment-chip-wrap{display:block}.assignment-chip{margin:3px 3px 0 0}.current-assignment-list{display:block}.current-assignment-list .assignment-chip{margin:3px 3px 0 0}}

/* v15 assignment remove guard */
.assignment-chip-removable {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding-right: .25rem;
}
.assignment-remove-btn {
    border: 0;
    background: rgba(185, 28, 28, .10);
    color: #b91c1c;
    border-radius: 999px;
    width: 20px;
    height: 20px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .65rem;
    margin-left: .25rem;
}
.assignment-remove-btn:hover {
    background: rgba(185, 28, 28, .18);
    color: #7f1d1d;
}
.assignment-remove-note {
    line-height: 1.35;
}
/* v18: robust Users module tabs */
.page-tabs.nav-tabs{gap:0;border-bottom:1px solid var(--line);background:#fff;margin:-20px -20px 18px;padding:0 22px;overflow-x:auto;white-space:nowrap}
.page-tabs.nav-tabs .nav-link{border:0;border-bottom:3px solid transparent;border-radius:0;background:transparent;color:#4d5b53;font-weight:600;padding:18px 14px 14px;margin:0}
.page-tabs.nav-tabs .nav-link:hover{color:var(--ksu);border-bottom-color:#a9dcc7}
.page-tabs.nav-tabs .nav-link.active{color:var(--ksu);background:transparent;border-bottom-color:var(--ksu)}
.users-tab-content .table-responsive{min-height:80px}
@media(max-width:992px){.page-tabs.nav-tabs{margin:-12px -12px 12px;padding:0 14px}.page-tabs.nav-tabs .nav-link{padding:14px 10px 12px;font-size:13px}}

/* v19: DataTables layout fix for Users tabs and wide tables */
.users-tab-content .dataTables_wrapper,
.card-soft .dataTables_wrapper{
  width:100%;
}
.users-tab-content table.dataTable,
table.users-datatable{
  width:100% !important;
  min-width:900px;
}
.users-tab-content .dataTables_scroll,
.users-tab-content .dataTables_scrollHead,
.users-tab-content .dataTables_scrollBody,
.users-tab-content .dataTables_scrollHeadInner,
.users-tab-content .dataTables_scrollHeadInner table{
  width:100% !important;
}
.users-tab-content .dataTables_scrollBody{
  border-bottom:0 !important;
}
.users-tab-content table.dataTable th,
.users-tab-content table.dataTable td{
  white-space:nowrap;
  vertical-align:middle;
}
.users-tab-content table.dataTable td.dt-wrap,
.users-tab-content table.dataTable th.dt-wrap{
  white-space:normal;
}
.users-tab-content .dataTables_length,
.users-tab-content .dataTables_filter{
  margin-bottom:.75rem;
}
.users-tab-content .dataTables_filter input{
  min-width:220px;
  max-width:100%;
}
.users-tab-content .dataTables_info,
.users-tab-content .dataTables_paginate{
  padding-top:.75rem;
}
@media(max-width:768px){
  .users-tab-content table.dataTable,
  table.users-datatable{min-width:760px;}
  .users-tab-content .dataTables_filter{ text-align:left !important; }
  .users-tab-content .dataTables_filter input{ min-width:160px; width:100%; margin-left:0; margin-top:.35rem; }
}


/* v21: mobile modal/backdrop touch fix */
.modal{z-index:2055!important;pointer-events:auto!important}
.modal-backdrop{z-index:2040!important}
body.modal-open .sidebar-backdrop{display:none!important}
.modal-dialog,.modal-content{pointer-events:auto!important}
.select2-container--open{z-index:2070!important}
@media(max-width:576px){
  .modal{padding-left:0!important;padding-right:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch}
  .modal-dialog{margin:.5rem auto!important;width:calc(100vw - 1rem)!important;max-width:calc(100vw - 1rem)!important}
  .modal-content{max-height:calc(100vh - 1rem);overflow:hidden}
  .modal-body{max-height:calc(100vh - 160px);overflow-y:auto;-webkit-overflow-scrolling:touch}
}


/* v22: final mobile modal touch fix
   Modals are moved to <body> by app.js. These rules keep the backdrop below the modal
   and remove stacking-context conflicts from the mobile layout. */
body.modal-open .main-panel,
body.modal-open .topbar,
body.modal-open .content-wrap{
  z-index:auto!important;
}
.modal{
  position:fixed!important;
  inset:0!important;
  z-index:20050!important;
  pointer-events:auto!important;
  touch-action:auto!important;
}
.modal.show{display:block!important;}
.modal-backdrop{
  z-index:20040!important;
  pointer-events:auto!important;
}
body.modal-open .sidebar,
body.modal-open .sidebar-backdrop{
  pointer-events:none!important;
}
.modal-dialog,
.modal-content,
.modal-header,
.modal-body,
.modal-footer,
.modal input,
.modal select,
.modal textarea,
.modal button,
.modal a,
.modal label{
  pointer-events:auto!important;
  touch-action:auto!important;
}
@media(max-width:576px){
  body.modal-open{overflow:hidden!important;touch-action:auto!important;}
  .modal{padding:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch;background:transparent!important;}
  .modal-dialog{margin:.5rem auto!important;width:calc(100vw - 1rem)!important;max-width:calc(100vw - 1rem)!important;}
  .modal-dialog.modal-dialog-centered{min-height:calc(100dvh - 1rem)!important;align-items:flex-start!important;padding-top:.5rem;}
  .modal-content{max-height:calc(100dvh - 1.5rem)!important;overflow:hidden!important;}
  .modal-body{max-height:calc(100dvh - 165px)!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch;}
  .modal .form-control,.modal .form-select,.modal textarea,.modal input,.modal select{
    font-size:16px!important; /* prevents mobile browser zoom/focus bugs */
  }
}

/* v30 nested indicator support */
.tree-node.indicator[style*="--indicator-depth"] .node-head,
.task-indicator[style*="--indicator-depth"] .node-head {
    margin-left: calc(var(--indicator-depth, 0) * 1.25rem);
}
.tree-node.indicator.has-child-indicators .node-head,
.task-indicator .badge.text-bg-light {
    background: #f7fbf8 !important;
}
.indicator-label {
    white-space: nowrap;
}
@media print {
    .badge { border: 0 !important; }
}

/* v31: Keep SweetAlert2 above all Bootstrap/custom modals globally.
   This fixes alerts appearing behind Create/Update/Upload/Indicator modals. */
.swal2-container,
.swal2-container.swal2-backdrop-show,
.swal2-container.swal2-noanimation,
.swal2-container.swal2-shown{
  z-index: 2147483000 !important;
  pointer-events: auto !important;
}
.swal2-popup{
  z-index: 2147483001 !important;
  pointer-events: auto !important;
}
.swal2-backdrop-show{
  background: rgba(0,0,0,.45) !important;
}
body.swal2-shown .modal.show{
  pointer-events: none !important;
}
body.swal2-shown .swal2-container,
body.swal2-shown .swal2-popup,
body.swal2-shown .swal2-confirm,
body.swal2-shown .swal2-cancel,
body.swal2-shown .swal2-deny,
body.swal2-shown .swal2-close,
body.swal2-shown .swal2-input,
body.swal2-shown .swal2-select,
body.swal2-shown .swal2-textarea{
  pointer-events: auto !important;
  touch-action: auto !important;
}

/* v37: Reports submenu moved to the left sidebar */
.side-submenu.report-submenu{
  margin:0;
  padding:4px 0 8px 0;
  background:rgba(7,92,59,.035);
  border-left:4px solid transparent;
}
.side-submenu.report-submenu .side-subitem{
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 12px 9px 54px;
  font-size:13px;
  font-weight:600;
  color:#42564a;
  text-decoration:none;
  border-left:0;
  background:transparent;
  line-height:1.25;
}
.side-submenu.report-submenu .side-subitem:hover{
  background:#e4eee8;
  color:var(--ksu);
}
.side-submenu.report-submenu .side-subitem.active{
  background:#ddefe7;
  color:var(--ksu);
  border-right:4px solid var(--ksu);
}
.side-submenu.report-submenu .side-subitem i{
  font-size:15px;
  width:18px;
  text-align:center;
  flex:0 0 18px;
}
.text-ksu{color:var(--ksu)!important}
.sidebar.collapsed .side-submenu.report-submenu{display:none}
@media(max-width:992px){
  .side-submenu.report-submenu .side-subitem{padding-left:52px;font-size:13px;}
}
