/* project.css — Project Management App (tema INDIGO). Komponen identik SDM/Finance; hanya brand di-recolor. */
:root {
  /* Design System v2 — brand Project = indigo. Token lama --orange* dialias ke --brand* (identik) */
  --brand:#5A4FCF; --brand-d:#453AA6; --brand-l:#ECEAFB;
  --orange:var(--brand); --orange-dark:var(--brand-d); --orange-light:var(--brand-l); --orange-accent:#A99FF0;
  --blue:#1A6DB5; --blue-light:#E8F2FB;
  --green:#3A9E4A; --green-light:#EAF6EC;
  --success:#2A7A37; --danger:#DC3545; --warning:#C25B12; --info:#1A6DB5;
  --gray-900:#1C2128; --gray-700:#3D4757; --gray-500:#6B7585;
  --gray-400:#9AA3B2; --gray-300:#C8CDD6; --gray-100:#F4F6F9; --gray-50:#FAFBFC; --gray-200:#E5E8EE; --white:#FFFFFF;
  --radius:10px;
  --shadow:0 2px 12px rgba(90,79,207,0.10);
  --shadow-lg:0 8px 32px rgba(90,79,207,0.16);
  --sidebar-w:200px; --topbar-h:56px;
  --gantt-label:178px;   /* lebar kolom label gantt (Workspace). Timeline override lokal. */
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Montserrat',sans-serif;background:var(--gray-100);color:var(--gray-900);font-size:14px;line-height:1.6;height:100vh;overflow:hidden}

/* APP SHELL */
#app-shell{display:flex;height:100vh}

/* SIDEBAR */
#sidebar{width:var(--sidebar-w);background:var(--orange-dark);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow-y:auto;scrollbar-width:none}
#sidebar::-webkit-scrollbar{display:none}
.sb-logo{padding:16px 14px;border-bottom:1px solid rgba(255,255,255,0.10);display:flex;align-items:center;gap:10px;flex-shrink:0}
.sb-logo img{height:34px;width:34px;object-fit:contain;flex-shrink:0}
.sb-logo-text{color:white;min-width:0}
.sb-logo-text .app-name{font-size:13px;font-weight:800;line-height:1.2;white-space:nowrap}
.sb-logo-text .app-sub{font-size:10px;opacity:0.6;font-weight:400}
.nav-group{padding:12px 14px 3px;font-size:10px;color:rgba(255,255,255,0.42);font-weight:700;letter-spacing:1.5px;text-transform:uppercase}
.nav-item{padding:9px 14px;font-size:12.5px;color:rgba(255,255,255,0.7);display:flex;align-items:center;gap:9px;cursor:pointer;transition:all 0.15s;border-left:3px solid transparent;user-select:none}
.nav-item:hover{background:rgba(255,255,255,0.10);color:white}
.nav-item.active{background:rgba(255,255,255,0.15);color:white;border-left-color:var(--orange-accent)}
.nav-item .ico{font-size:14px;width:17px;text-align:center;flex-shrink:0}

/* MAIN */
#main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
#topbar{height:var(--topbar-h);background:var(--white);border-bottom:1px solid var(--gray-300);display:flex;align-items:center;padding:0 22px;gap:12px;flex-shrink:0;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
#topbar-title{font-size:16px;font-weight:700;color:var(--gray-900);flex:1}
/* aksi halaman (DDS): bar di bawah topbar, rata-kanan, sembunyi saat kosong */
#topbar-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap;padding:11px 22px 0;flex-shrink:0}
#topbar-actions:empty{display:none}
#content{flex:1;overflow-y:auto;padding:22px}
.page{display:none}.page.active{display:block}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all 0.15s;font-family:inherit;text-decoration:none}
.btn-primary{background:var(--orange);color:white}.btn-primary:hover{background:var(--orange-dark)}
.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-100)}
.btn-danger{background:#DC3545;color:white}.btn-danger:hover{background:#B02A37}
.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}
.btn-icon{padding:5px 7px}

/* CARDS / GRID */
.card{background:white;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,0.04);margin-bottom:16px}
.card-title{font-size:14px;font-weight:700;color:var(--gray-900);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* TABLE */
.tbl-wrap{overflow-x:auto;border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--orange-dark);color:white;padding:9px 13px;text-align:left;font-weight:600;font-size:12px;white-space:nowrap}
thead th:first-child{border-radius:8px 0 0 0}thead th:last-child{border-radius:0 8px 0 0}
tbody td{padding:8px 13px;border-bottom:1px solid var(--gray-100);color:var(--gray-700);vertical-align:middle}
tbody tr:hover td{background:var(--gray-100)}tbody tr:last-child td{border-bottom:none}

/* FORM */
.fg{margin-bottom:14px}
.fl{display:block;font-size:12px;font-weight:600;color:var(--gray-700);margin-bottom:4px}
.fl .req{color:#dc3545;margin-left:2px}
.fi,.fs,.fta{width:100%;padding:8px 11px;border:1px solid var(--gray-300);border-radius:7px;font-size:13px;font-family:inherit;color:var(--gray-900);background:white;transition:border-color 0.15s;outline:none}
.fi:focus,.fs:focus,.fta:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(199,90,0,0.12)}
.fi.err,.fs.err{border-color:#dc3545}
.fta{resize:vertical;min-height:64px}
.fhint{font-size:11px;color:var(--gray-500);margin-top:3px}

/* BADGE */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700}
.badge-blue,.b-blue{background:var(--blue-light);color:var(--blue)}
.badge-green,.b-green{background:var(--green-light);color:var(--green)}
.badge-orange,.b-orange{background:var(--orange-light);color:var(--orange)}
.badge-gray,.b-gray{background:var(--gray-100);color:var(--gray-500)}
.badge-red,.b-red{background:#FEE2E2;color:#DC3545}
.badge-owner,.b-owner{background:#f3e8ff;color:#6c3483;font-weight:800}
/* badge semantik kanonik v2 (status) */
.badge-success{background:var(--green-light);color:var(--success)}
.badge-danger{background:#FEE2E2;color:var(--danger)}
.badge-warning{background:var(--orange-light);color:var(--warning)}
.badge-info{background:var(--blue-light);color:var(--info)}

/* MODAL */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:1000;align-items:center;justify-content:center;padding:16px}
.mo.open{display:flex}
.mb{background:white;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:moin 0.2s ease}
.mb.lg{max-width:820px}
@keyframes moin{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}
.mh{padding:18px 22px 14px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}
.mt{font-size:15px;font-weight:700;color:var(--gray-900)}
.mx{width:26px;height:26px;border:none;background:var(--gray-100);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--gray-500);transition:all 0.15s}
.mx:hover{background:var(--gray-300);color:var(--gray-900)}
.mbdy{padding:18px 22px}
.mf{padding:12px 22px;border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end;gap:8px}

/* TOAST */
#toast-box{position:fixed;bottom:22px;right:22px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:white;border-radius:10px;padding:11px 15px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;min-width:260px;max-width:340px;animation:tin 0.3s ease;border-left:4px solid var(--orange)}
.toast.s{border-left-color:var(--green)}.toast.e{border-left-color:#DC3545}.toast.w{border-left-color:var(--orange)}
@keyframes tin{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
.ti{font-size:17px}.tm{font-size:12.5px;color:var(--gray-700);flex:1}

/* TABS */
.tabs{display:flex;gap:2px;border-bottom:2px solid var(--gray-300);margin-bottom:18px}
.tab{padding:9px 15px;font-size:13px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all 0.15s;border-radius:4px 4px 0 0}
.tab:hover{color:var(--orange)}.tab.active{color:var(--orange);border-bottom-color:var(--orange)}

/* STAT */
.stat{background:white;border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,0.04)}
.stat .lbl{font-size:11px;color:var(--gray-500);font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.stat .val{font-size:22px;font-weight:800;color:var(--gray-900);margin:3px 0;font-family:'Fira Code',monospace}
.stat .sub{font-size:11px;color:var(--gray-500)}

/* FILTER BAR / EMPTY STATE */
.fb{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.fb .fi,.fb .fs{width:auto;min-width:130px}
.es{text-align:center;padding:42px 20px;color:var(--gray-500)}
.es-ico{font-size:44px;margin-bottom:10px;opacity:0.35}
.es-t{font-size:14px;font-weight:700;margin-bottom:4px}
.es-s{font-size:12px}

/* PROGRESS / MINI (honor bars, team) */
.proj-prog{height:6px;background:var(--gray-300);border-radius:3px;overflow:hidden;margin-top:4px}
.proj-prog-fill{height:100%;background:var(--orange);border-radius:3px;transition:width 0.3s}

/* ── WORKSPACE: ring progress + sub-tabs + GANTT timeline ── */
.ws-head{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.ring{--p:0;width:62px;height:62px;border-radius:50%;background:conic-gradient(var(--brand) calc(var(--p)*1%),var(--gray-300) 0);display:flex;align-items:center;justify-content:center;flex:none;position:relative}
.ring::before{content:'';position:absolute;width:46px;height:46px;border-radius:50%;background:#fff}
.ring b{position:relative;font-size:13px;font-weight:800;color:var(--brand-d)}
.subtabs{display:flex;gap:3px;border-bottom:2px solid var(--gray-300);margin:14px 0 16px;flex-wrap:wrap}
.subtab{padding:8px 13px;font-size:12.5px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;border-radius:5px 5px 0 0}
.subtab.active{color:var(--brand);border-bottom-color:var(--brand)}
.subtab:hover{color:var(--brand)}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--brand-l);color:var(--brand-d);border:1px solid #d9d4f5;border-radius:20px;padding:4px 11px;font-size:12px;font-weight:600;margin:2px}
.chip.pic{background:#fff4d6;color:#9a7b12;border-color:#ecdca0}
.chip .cx{cursor:pointer;opacity:.6;font-weight:800}.chip .cx:hover{opacity:1}
.gantt{overflow-x:auto;padding-bottom:6px}
.gantt-inner{min-width:640px;position:relative}
.gmonths{position:relative;height:20px;font-size:9.5px;color:var(--gray-500);font-weight:700;border-bottom:1px solid var(--gray-200);margin:0 0 0 var(--gantt-label)}
.gmonths span{position:absolute;top:4px;transform:translateX(-50%);white-space:nowrap}
.gcol{position:absolute;top:20px;bottom:0;width:1px;background:var(--gray-100);z-index:0}
.gcol-month{background:var(--gray-300);width:2px;top:0}
.gcol-off{position:absolute;top:20px;bottom:0;background:rgba(220,53,69,.07);z-index:0}   /* kolom weekend/libur nasional — hanya mode harian */
.gmonths span.off{color:#DC3545;font-weight:800}                                          /* angka tanggal weekend/libur → merah */
.glay{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 11px;font-size:12px;font-weight:800;color:var(--brand-d);background:var(--brand-l);border-left:4px solid var(--brand);border-radius:5px;margin:12px 0 3px;position:relative;z-index:1}
.grow{display:grid;grid-template-columns:var(--gantt-label) 1fr;align-items:center;min-height:20px;position:relative;z-index:1}
/* Timeline (Gantt) lintas-project: klien dikelompokkan, label 2 kolom (klien | kode layanan) */
.tl-grp{display:grid;grid-template-columns:120px 1fr;position:relative;z-index:1}
.tl-grp + .tl-grp{border-top:3px solid var(--gray-400)}
.tl-k{display:flex;align-items:center;justify-content:center;text-align:center;font-weight:800;color:var(--brand-d);font-size:11.5px;padding:5px 6px;border-right:1px solid var(--gray-300);word-break:break-word;overflow-wrap:anywhere;line-height:1.25}
.tl-lays{min-width:0}
.tl-row{display:grid;grid-template-columns:100px 1fr;align-items:center;min-height:22px;cursor:pointer}
.tl-row + .tl-row{border-top:1px solid var(--gray-100)}
.tl-row:hover{background:var(--gray-50)}
.tl-laylabel{font-size:11px;font-weight:600;color:var(--gray-700);padding:4px 7px;line-height:1.3;word-break:break-word;overflow-wrap:anywhere}
.glabel{font-size:11.5px;font-weight:600;padding:1px 8px 1px 2px;display:flex;align-items:center;gap:6px;justify-content:flex-start}
.gtrack{position:relative;height:20px}
.gbar{position:absolute;top:2px;height:16px;border-radius:4px;display:flex;align-items:center;padding:0 7px;font-size:9.5px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.18);cursor:pointer;z-index:2}
.gbar.selesai{background:var(--green)}
.gbar.selesai_telat{background:#DC3545}
.gbar.telat{background:#DC3545}
.gbar.rencana{background:var(--brand);color:#fff}
.gbar.none{background:var(--gray-300);color:var(--gray-700)}
.gtoday{position:absolute;top:20px;bottom:0;width:2px;background:#F07C28;z-index:3}
.gtoday::after{content:'Hari ini';position:absolute;top:-16px;left:50%;transform:translateX(-50%);font-size:8.5px;font-weight:800;color:#F07C28;white-space:nowrap}
.glegend{display:flex;gap:14px;margin-top:12px;font-size:11px;color:var(--gray-500);flex-wrap:wrap;align-items:center}
.glegend i{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:-1px;margin-right:3px}

/* ── KANBAN (Papan Tugas) ── */
.kb{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;align-items:start}
@media(max-width:900px){.kb{grid-template-columns:repeat(2,1fr)}}
.kcol{background:var(--gray-100);border-radius:10px;padding:10px;min-height:90px}
.kcol-h{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);margin-bottom:8px;display:flex;justify-content:space-between}
.kcard{background:#fff;border:1px solid var(--gray-300);border-radius:8px;padding:9px 10px;margin-bottom:8px;box-shadow:0 1px 2px rgba(0,0,0,.04);font-size:12px;cursor:grab}
.kcard:hover{border-color:var(--brand)}
.kcard.done{background:var(--gray-50);padding:6px 10px;color:var(--gray-500)}
.kcard .ktitle{font-weight:600;margin-bottom:3px}
.kcard.done .ktitle{font-weight:500;font-size:11.5px;text-decoration:line-through;margin:0}
.kfase{font-size:9.5px;font-weight:700;color:var(--brand-d);background:var(--brand-l);border-radius:5px;padding:1px 6px}
.kchips{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.ktag{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;background:#eef0ff;color:var(--brand-d);border-radius:20px;padding:1px 7px}
.kmeta{display:flex;gap:8px;align-items:center;margin-top:5px;font-size:10px;color:var(--gray-500)}
.kadd{width:100%;border:1px dashed var(--gray-300);background:none;color:var(--gray-500);border-radius:7px;padding:6px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}
.kadd:hover{border-color:var(--brand);color:var(--brand)}

/* ── MILESTONE ── */
.ms{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--gray-100);font-size:13px}
.ms .msdot{width:18px;height:18px;border-radius:50%;border:2px solid var(--gray-300);flex:none;cursor:pointer}
.ms.ok .msdot{background:var(--green);border-color:var(--green)}
.ms.ok .mst{text-decoration:line-through;color:var(--gray-500)}
.ms .msx{margin-left:auto;cursor:pointer;color:var(--gray-400);font-weight:800}
.ms .msx:hover{color:#DC3545}

/* ── KALENDER ── */
.calbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.calgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.caldow{font-size:10px;font-weight:700;color:var(--gray-500);text-align:center;padding:4px;text-transform:uppercase;letter-spacing:.5px}
.calday{background:var(--gray-50);border-radius:7px;min-height:78px;padding:5px;font-size:11px;border:1.5px solid transparent;overflow:hidden;cursor:pointer;transition:background .12s}
.calday:hover{background:var(--gray-100)}
.calday.other{opacity:.45}
.calday.today{border-color:var(--brand);background:var(--brand-l)}
.calday.sel{outline:2px solid var(--brand);outline-offset:-2px}
.calday .cn{font-weight:700;color:var(--gray-700);font-size:11px;margin-bottom:2px}
.cpill{font-size:9px;font-weight:700;border-radius:4px;padding:1px 5px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmore{font-size:9px;color:var(--gray-500);margin-top:2px;font-weight:600}
.proj-mini{background:var(--gray-100);border-radius:8px;padding:10px;text-align:center}
.proj-mini .pm-l{font-size:10px;color:var(--gray-500);font-weight:700;text-transform:uppercase}
.proj-mini .pm-v{font-size:14px;font-weight:700;font-family:'Fira Code',monospace;margin-top:2px}

/* TEAM CHIPS (penugasan) */
.tim-chips{display:flex;flex-wrap:wrap;gap:6px}
.tim-chip{display:inline-flex;align-items:center;gap:5px;background:var(--orange-light);color:var(--orange-dark);border:1px solid #f0cfa8;border-radius:20px;padding:3px 10px;font-size:11.5px;font-weight:600}
.tim-chip .role{color:var(--gray-500);font-weight:500}
.tim-chip.pic{background:#fff3d6;border-color:#f0c674}
.tim-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.tim-row .fs{flex:1}

/* REKRUTMEN board */
.rec-board{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;align-items:start}
.rec-col{background:var(--gray-100);border-radius:10px;padding:10px;min-height:90px}
.rec-col-head{font-size:12px;font-weight:700;color:var(--gray-700);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.rec-card{background:#fff;border:1px solid var(--gray-300);border-radius:8px;padding:9px 10px;margin-bottom:8px;box-shadow:0 1px 2px rgba(0,0,0,0.04)}
@media (max-width:900px){.rec-board{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.rec-board{grid-template-columns:1fr}}

/* CONFIRM */
#cdlg{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:2000;align-items:center;justify-content:center}
#cdlg.open{display:flex}
#cbox{background:white;border-radius:12px;padding:22px;max-width:360px;width:90%;box-shadow:var(--shadow-lg)}
#cbox h3{font-size:14px;margin-bottom:7px}#cbox p{font-size:13px;color:var(--gray-700);margin-bottom:18px}
#cbox .cbtns{display:flex;gap:8px;justify-content:flex-end}

/* UTILS */
.cur{font-family:'Fira Code',monospace}
.muted{color:var(--gray-500)}
.tg{color:var(--green)}.tr{color:#DC3545}.tgr{color:var(--gray-500)}
.fw7{font-weight:700}.tsm{font-size:12px}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}

/* SIDEBAR FOOTER (Beranda + collapse) — konsisten Admin/Finance */
.sb-bottom{margin-top:auto;padding:10px;border-top:1px solid rgba(255,255,255,0.10);display:flex;gap:6px;align-items:center}
.sb-back-btn{flex:1;display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;color:rgba(255,255,255,0.78);text-decoration:none;font-size:12.5px;background:rgba(255,255,255,0.08);transition:all .15s;white-space:nowrap}
.sb-back-btn:hover{background:rgba(255,255,255,0.18);color:#fff}
.sb-back-btn .ico{font-size:15px;width:17px;text-align:center;flex-shrink:0}
.sb-toggle-btn{width:30px;height:30px;border:none;border-radius:7px;background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.78);cursor:pointer;font-size:17px;line-height:1;transition:all .15s;flex-shrink:0}
.sb-toggle-btn:hover{background:rgba(255,255,255,0.18);color:#fff}
#sidebar.collapsed{width:60px}
#sidebar.collapsed .sb-logo-text,
#sidebar.collapsed .nav-item span:not(.ico),
#sidebar.collapsed .sb-back-btn span:not(.ico){display:none}
#sidebar.collapsed .nav-item,#sidebar.collapsed .sb-back-btn{justify-content:center}
#sidebar.collapsed .sb-logo{justify-content:center;padding:14px 0}
#sidebar.collapsed .sb-toggle-btn{transform:rotate(180deg)}

/* ════════ Design System v2 — chrome topbar + dashboard widgets ════════ */
.nav-item .ico{display:inline-flex;align-items:center;justify-content:center}
.nav-item .ico svg{width:16px;height:16px}
.topbar-chrome{display:flex;align-items:center;gap:6px;flex-shrink:0}
.tb-ico-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;color:var(--gray-500);background:transparent;border:1px solid transparent;transition:all .15s}
.tb-ico-btn:hover{color:var(--brand);background:var(--brand-l)}
.tb-ico-btn svg{width:18px;height:18px}
.tb-user{display:inline-flex;align-items:center;gap:6px;padding:5px 11px 5px 8px;border-radius:20px;background:var(--gray-100);color:var(--gray-900);font-size:12px;font-weight:600}
.tb-user svg{width:16px;height:16px;color:var(--brand);flex:none}
@media (max-width:768px){ .tb-user .tb-uname{display:none} }

/* KPI dashboard — ikon di label + rincian status */
.kpi-row{display:flex;align-items:center;gap:6px;color:var(--gray-500);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.kpi-row svg{flex:none}
.kpi-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.kpi-chip{font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px;background:var(--gray-100);color:var(--gray-500)}

/* Beban kerja (workload bars) */
.wl-row{display:flex;align-items:center;gap:10px;margin-bottom:9px;font-size:12.5px}
.wl-name{flex:0 0 33%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.wl-bar-track{flex:1;height:8px;background:var(--gray-100);border-radius:20px;overflow:hidden}
.wl-bar-fill{height:100%;background:var(--brand);border-radius:20px;min-width:3px}
.wl-bar-fill.over{background:var(--danger)}
.wl-n{flex:0 0 auto;font-family:'Fira Code',monospace;font-size:12px;color:var(--gray-700);min-width:18px;text-align:right}
.wl-honor{flex:0 0 auto;font-family:'Fira Code',monospace;font-size:11.5px;color:var(--gray-500);min-width:96px;text-align:right}
.dash-lock{display:inline-flex;align-items:center;gap:4px;color:var(--gray-300);font-size:11px}

/* Perlu tindakan */
.act-item{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:8px;font-size:12px;margin-bottom:7px;cursor:pointer;text-decoration:none;color:inherit}
.act-item.warn{background:var(--orange-light);color:#b55a00}
.act-item.danger{background:#FCE8EA;color:#B02A37}
.act-item.info{background:var(--blue-light);color:#155a96}
.act-item svg{flex:none}
.act-item .act-n{font-weight:800;font-family:'Fira Code',monospace}

/* Panel CDO */
.cdo-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cdo-mini{background:var(--gray-100);border-radius:9px;padding:12px 14px}
.cdo-mini .cm-l{font-size:10.5px;color:var(--gray-500);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.cdo-mini .cm-v{font-size:17px;font-weight:800;margin-top:3px}
.cdo-mini .cm-s{font-size:11px;color:var(--gray-500);margin-top:1px}

/* ════════ Editor Kontrak — pratinjau A4 editable (port pola Admin) ════════ */
.ktr-editor-wrap{display:grid;grid-template-columns:1fr 270px;gap:16px;align-items:start}
.paper-scaler{width:100%;overflow:hidden;background:var(--gray-100);border-radius:8px;padding:14px}
.paper-sheet{width:210mm;min-height:297mm;background:#fff;box-shadow:0 2px 18px rgba(0,0,0,.18);transform-origin:top left;position:relative;background-repeat:repeat-y;background-position:top center;background-size:100% 297mm}
.paper-body{padding:30mm 25mm 25mm 25mm;font-family:'Times New Roman',serif;font-size:12pt;color:#111;position:relative;z-index:1}
.paper-editable{min-height:160mm;outline:none}
.paper-editable p{margin:0 0 6pt}
.paper-editable table{width:100%;border-collapse:collapse}
.paper-editable td{vertical-align:top;padding:0 0 2pt}
.paper-kop-hint{position:absolute;top:8mm;left:0;right:0;text-align:center;font-size:9px;color:#c9c9c9;letter-spacing:3px;z-index:0}
.ktr-side .fl{font-size:11px}
.ktr-side .fi,.ktr-side .fs{padding:5px 8px;font-size:12px}
.ktr-tb{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.ktr-tb-btn{min-width:30px;height:28px;border:1px solid var(--gray-300);background:#fff;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:13px;color:var(--gray-700);padding:0 6px}
.ktr-tb-btn:hover{background:var(--brand-l);border-color:var(--brand)}
@media (max-width:900px){ .ktr-editor-wrap{grid-template-columns:1fr} .paper-scaler{order:2} }

/* RAMAH HP */
@media (max-width:768px){
  html,body{height:auto;min-height:100vh;overflow-x:hidden}
  body{overflow-y:auto}
  #app-shell{flex-direction:column;height:auto}
  #sidebar{width:100%;height:auto;flex-direction:row;overflow-x:auto;overflow-y:hidden;position:sticky;top:0;z-index:30}
  .sb-logo{padding:10px 12px;border-bottom:none;border-right:1px solid rgba(255,255,255,0.10)}
  .sb-logo-text{display:none}
  .nav-group{display:none}
  .nav-item{border-left:none;border-bottom:3px solid transparent;white-space:nowrap;padding:12px 14px}
  .nav-item.active{border-left-color:transparent;border-bottom-color:var(--orange-accent)}
  .sb-bottom{display:none}
  #main-area{overflow:visible;height:auto}
  #topbar{padding:0 14px}#topbar-title{font-size:15px}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .cdo-mini-grid{grid-template-columns:1fr}
  .card{padding:16px}
  .tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .tab{white-space:nowrap}
}
/* ── Input mention berbasis chip + dropdown autocomplete (komponen MEN) ── */
.men-box{display:flex;flex-wrap:wrap;align-items:center;gap:5px;min-height:38px;padding:5px 8px;border:1px solid var(--gray-300);border-radius:8px;background:#fff;cursor:text}
.men-box:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.men-chip{display:inline-flex;align-items:center;gap:4px;background:var(--brand-l);color:var(--brand-d);border:1px solid #d9d4f5;border-radius:20px;padding:2px 9px;font-size:12px;font-weight:600;white-space:nowrap}
.men-chip .men-x{cursor:pointer;opacity:.55;font-weight:800;margin-left:1px}
.men-chip .men-x:hover{opacity:1;color:#dc2626}
.men-input{flex:1;min-width:90px;border:none;outline:none;font-size:13px;background:transparent;padding:2px 1px}
.men-dd{position:absolute;z-index:99999;background:#fff;border:1px solid var(--gray-300);border-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,.14);max-height:240px;overflow-y:auto;display:none;padding:3px}
.men-dd.open{display:block}
.men-opt{display:flex;align-items:center;gap:7px;padding:7px 10px;font-size:13px;cursor:pointer;color:var(--gray-800);border-radius:6px}
.men-opt:hover,.men-opt.hi{background:var(--brand-l);color:var(--brand-d)}
