:root{
  --bg:#f4f7fb;
  --panel:#ffffff;
  --ink:#0f1f33;
  --ink-2:#41546b;
  --muted:#7a8ca0;
  --line:#e4ebf3;
  --brand:#0a6f82;
  --brand-2:#0e8aa3;
  --brand-soft:#e6f4f7;
  --teal:#0d9488;
  --green:#15803d;
  --green-soft:#e7f4ea;
  --amber:#b45309;
  --amber-soft:#fdf2e3;
  --red:#b91c1c;
  --red-soft:#fdeaea;
  --shadow:0 1px 2px rgba(16,32,52,.04),0 6px 20px rgba(16,32,52,.06);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;
}
.app{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{
  width:284px;flex:0 0 284px;background:var(--panel);
  border-right:1px solid var(--line);display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow:hidden;
}
.brand{display:flex;align-items:center;gap:12px;padding:18px 18px 14px}
.brand-logo{
  width:46px;height:46px;border-radius:12px;flex:0 0 46px;
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(0,0,0,.08);
  overflow:hidden;
}
.brand-img{width:100%;height:100%;object-fit:contain;display:block;padding:3px;box-sizing:border-box}
.brand-title{font-weight:800;font-size:15px;line-height:1.2}
.brand-sub{font-size:11.5px;color:var(--muted);font-weight:500}
.nav{display:flex;flex-direction:column;padding:6px 10px;gap:2px}
.nav-item{
  appearance:none;border:0;background:transparent;text-align:left;
  padding:9px 12px;border-radius:10px;font-size:13.5px;font-weight:600;
  color:var(--ink-2);cursor:pointer;display:flex;align-items:center;gap:10px;
  transition:.15s;
}
.nav-item:hover{background:var(--brand-soft);color:var(--brand)}
.nav-item.active{background:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(10,111,130,.3)}
.nav-ic{width:18px;display:inline-flex;justify-content:center;font-size:14px}
.side-search{padding:8px 14px 4px}
.side-search input{
  width:100%;border:1px solid var(--line);border-radius:10px;
  padding:8px 11px;font-size:13px;outline:none;background:#f8fbfd;color:var(--ink);
}
.side-search input:focus{border-color:var(--brand-2);background:#fff}
.side-section{
  padding:12px 18px 6px;font-size:11px;font-weight:700;letter-spacing:.6px;
  text-transform:uppercase;color:var(--muted);
}
.prof-list{overflow-y:auto;flex:1;padding-bottom:10px}
.prof-group-label{
  padding:10px 18px 4px;font-size:10.5px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--brand);opacity:.85;
}
.prof-item{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:7px 12px;margin:1px 6px;border-radius:9px;cursor:pointer;
  font-size:13px;font-weight:500;color:var(--ink-2);transition:.15s;
}
.prof-item:hover{background:var(--brand-soft);color:var(--brand)}
.prof-item.active{background:var(--brand-soft);color:var(--brand);font-weight:700}
.prof-item .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.prof-item .badge{
  flex:0 0 auto;font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:20px;
  background:#eef3f8;color:var(--ink-2);
}
.prof-item.active .badge{background:var(--brand);color:#fff}
.side-foot{padding:10px 18px;font-size:10.5px;color:var(--muted);border-top:1px solid var(--line)}

/* Main */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:20;background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);display:flex;align-items:center;gap:14px;
  padding:14px 22px;border-bottom:1px solid var(--line);
}
.menu-btn{display:none;border:0;background:transparent;font-size:20px;cursor:pointer;color:var(--ink)}
.topbar-title{font-size:17px;font-weight:800;flex:0 0 auto}
.topbar-search{flex:1;max-width:480px;margin-left:auto}
.topbar-search input{
  width:100%;border:1px solid var(--line);border-radius:10px;
  padding:9px 13px;font-size:13.5px;outline:none;background:#fff;color:var(--ink);
}
.topbar-search input:focus{border-color:var(--brand-2);box-shadow:0 0 0 3px var(--brand-soft)}
.content{padding:22px;flex:1}

/* KPI cards */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:20px}
.kpi{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.kpi .lbl{font-size:11.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.kpi .val{font-size:26px;font-weight:800;margin-top:6px;letter-spacing:-.5px}
.kpi .sub{font-size:12px;color:var(--ink-2);margin-top:2px}
.kpi .accent{position:absolute;right:-18px;top:-18px;width:74px;height:74px;border-radius:50%;opacity:.12}
.kpi.k-total .val{color:var(--brand)}
.kpi.k-total .accent{background:var(--brand)}
.kpi.k-isi .val{color:var(--green)}
.kpi.k-isi .accent{background:var(--green)}
.kpi.k-kosong .val{color:var(--red)}
.kpi.k-kosong .accent{background:var(--red)}
.kpi.k-peratus .val{color:var(--teal)}
.kpi.k-peratus .accent{background:var(--teal)}

/* Panels */
.panel{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);margin-bottom:18px;
}
.panel-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--line);
}
.panel-title{font-size:14.5px;font-weight:700;margin:0}
.panel-sub{font-size:12px;color:var(--muted);font-weight:500}
.panel-body{padding:16px 18px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:1100px){.grid-2,.grid-3{grid-template-columns:1fr}}
.chart-wrap{position:relative;height:300px}
.chart-wrap.tall{height:360px}
.chart-wrap.short{height:240px}

/* Profession header */
.prof-header{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#fff;border-radius:var(--radius);padding:22px 24px;margin-bottom:18px;
  box-shadow:0 10px 30px rgba(10,111,130,.25);
}
.prof-header .ph-group{font-size:11.5px;font-weight:600;opacity:.85;text-transform:uppercase;letter-spacing:.6px}
.prof-header h1{margin:4px 0 14px;font-size:22px;font-weight:800;letter-spacing:-.3px}
.ph-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px}
.ph-stat{background:rgba(255,255,255,.12);border-radius:12px;padding:10px 14px;backdrop-filter:blur(4px)}
.ph-stat .l{font-size:11px;opacity:.85;font-weight:600}
.ph-stat .v{font-size:20px;font-weight:800;margin-top:2px}
.ph-bar{margin-top:16px;height:10px;background:rgba(255,255,255,.2);border-radius:20px;overflow:hidden}
.ph-bar > span{display:block;height:100%;background:#fff;border-radius:20px;transition:width .8s}
.ph-bar-lbl{display:flex;justify-content:space-between;font-size:12px;margin-top:6px;opacity:.9}

/* Filters */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.filters label{font-size:12px;font-weight:600;color:var(--ink-2)}
.filters select,.filters input{
  border:1px solid var(--line);border-radius:9px;padding:8px 11px;font-size:13px;
  background:#fff;color:var(--ink);outline:none;
}
.filters select:focus,.filters input:focus{border-color:var(--brand-2);box-shadow:0 0 0 3px var(--brand-soft)}
.seg{display:inline-flex;background:#eef3f8;border-radius:9px;padding:3px;gap:2px}
.seg button{
  border:0;background:transparent;padding:6px 12px;border-radius:7px;font-size:12.5px;
  font-weight:600;color:var(--ink-2);cursor:pointer;
}
.seg button.active{background:#fff;color:var(--brand);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.spacer{flex:1}
.result-count{font-size:12.5px;color:var(--muted);font-weight:600}

/* Table */
.table-scroll{overflow-x:auto;border-radius:10px;border:1px solid var(--line)}
table.data{width:100%;border-collapse:collapse;font-size:13px;min-width:760px}
table.data thead th{
  background:#f8fbfd;text-align:left;padding:11px 12px;font-size:11.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.4px;color:var(--ink-2);
  border-bottom:1px solid var(--line);position:sticky;top:0;cursor:pointer;white-space:nowrap;
  user-select:none;
}
table.data thead th .sort-ic{opacity:.4;font-size:10px;margin-left:4px}
table.data thead th.sorted .sort-ic{opacity:1;color:var(--brand)}
table.data tbody td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
table.data tbody tr:nth-child(even){background:#fafcfe}
table.data tbody tr:hover{background:var(--brand-soft)}
table.data tbody tr.vacant{background:var(--red-soft)}
table.data tbody tr.vacant:hover{background:#fbdcdc}
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}
.pill.isi{background:var(--green-soft);color:var(--green)}
.pill.kosong{background:var(--red-soft);color:var(--red)}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.muted{color:var(--muted)}
.nama-cell{font-weight:600;color:var(--ink)}
.ptj-cell{font-weight:600}
.gred-tag{display:inline-block;font-family:'Inter';font-weight:700;font-size:11.5px;background:#eef3f8;color:var(--ink-2);padding:2px 8px;border-radius:6px}
.wrap-cell{white-space:pre-wrap;max-width:340px;font-size:12.5px;line-height:1.45}

/* Summary table specifics */
table.summary td.num,table.data td.num{text-align:right;font-variant-numeric:tabular-nums}
.bar-inline{height:8px;background:#eef3f8;border-radius:20px;overflow:hidden;min-width:80px;display:inline-block;vertical-align:middle}
.bar-inline > span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--brand-2));border-radius:20px}

/* Empty / loading */
.empty{padding:40px;text-align:center;color:var(--muted)}
.loading{padding:60px;text-align:center;color:var(--muted)}

/* Mobile */
@media(max-width:860px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:.25s;z-index:50;box-shadow:0 0 40px rgba(0,0,0,.2)}
  .sidebar.open{transform:none}
  .menu-btn{display:block}
  .topbar-search{display:none}
  .content{padding:16px}
  .prof-header h1{font-size:18px}
}
.scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:40}
.scrim.show{display:block}

/* Admin button */
.admin-btn{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;
  border:1px solid var(--line);background:#fff;color:var(--ink-2);
  padding:8px 13px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;
  transition:.15s;
}
.admin-btn:hover{background:var(--brand-soft);color:var(--brand);border-color:var(--brand-2)}
.admin-btn.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.admin-ic{font-size:15px}
@media(max-width:860px){ .admin-lbl{display:none} }

/* Modal */
.modal{display:none;position:fixed;inset:0;z-index:80;background:rgba(13,30,50,.45);
  backdrop-filter:blur(3px);align-items:center;justify-content:center;padding:20px}
.modal.show{display:flex}
.modal-card{width:100%;max-width:380px;background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}
.modal-title{font-weight:800;font-size:15px}
.modal-x{border:0;background:transparent;font-size:22px;line-height:1;color:var(--muted);cursor:pointer}
.modal-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:10px}
.modal-help{margin:0;font-size:13px;color:var(--ink-2)}
.modal-err{min-height:16px;font-size:12px;color:var(--red);font-weight:600}
.modal-hint{font-size:11.5px;color:var(--muted)}
.modal-hint code{background:#eef3f8;padding:1px 6px;border-radius:5px;font-weight:700}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}
.btn{border:1px solid var(--line);background:#fff;color:var(--ink-2);padding:9px 14px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;transition:.15s}
.btn:hover{background:#f4f7fb}
.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn.primary:hover{background:var(--brand-2)}
.btn.danger{color:var(--red);border-color:#f3cfcf}
.btn.danger:hover{background:var(--red-soft)}
.btn.ghost{background:transparent}

/* Admin panel */
.admin-banner{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:linear-gradient(135deg,#1f2d3d,#2b3f57);color:#fff;
  border-radius:12px;padding:12px 16px;margin-bottom:16px;
}
.admin-banner .ab-title{font-weight:800;font-size:14px}
.admin-banner .ab-sub{font-size:12px;opacity:.8}
.admin-banner .spacer{flex:1}
.admin-banner .btn{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.2)}
.admin-banner .btn:hover{background:rgba(255,255,255,.22)}
.admin-banner .btn.danger{background:rgba(185,28,28,.25);border-color:rgba(185,28,28,.5);color:#ffd5d5}

.admin-layout{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.admin-topbar{
  display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;
  padding:12px 14px;border-bottom:1px solid var(--line);background:#f8fbfc;
}
.prof-pick-row{display:flex;align-items:center;gap:8px;flex-shrink:0}
.prof-pick-row label{font-size:12px;font-weight:700;color:var(--ink-2);white-space:nowrap;margin:0}
.prof-pick-row select{
  min-width:200px;max-width:340px;border:1px solid var(--line);border-radius:8px;
  padding:8px 10px;font-size:13px;background:#fff;color:var(--ink);outline:none;
}
.prof-pick-row select:focus{border-color:var(--brand-2);box-shadow:0 0 0 2px var(--brand-soft)}
.prof-pick-row .as-prof-name{
  font-weight:700;font-size:13px;color:var(--brand);
  padding:6px 10px;background:var(--brand-soft);border-radius:8px;white-space:nowrap;
}
.admin-topbar-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;flex:1;
  font-size:12px;color:var(--muted);min-width:0;
}
.admin-topbar-meta .as-stat b{color:var(--ink)}
.admin-topbar-actions{display:flex;gap:8px;flex-shrink:0;margin-left:auto}
.admin-edit{padding:12px}
.admin-edit .col-bil{width:42px;min-width:42px}
.admin-edit .col-move{width:52px;min-width:52px;text-align:center;vertical-align:middle}
.admin-edit .row-handle{cursor:grab;color:var(--muted);font-weight:800;user-select:none;font-size:14px;line-height:1}
.admin-edit tr.admin-data-row{cursor:grab}
.admin-edit tr.admin-data-row.dragging{opacity:.45}
.admin-edit tr.admin-data-row.drag-over td{background:var(--brand-soft)!important}
.admin-edit tr.admin-data-row.row-highlight td{background:#fff3cd!important;transition:background .4s}
.admin-edit .row-up,.admin-edit .row-down{
  border:0;background:transparent;cursor:pointer;color:var(--brand);
  font-size:11px;padding:0 2px;border-radius:4px;line-height:1;vertical-align:middle;
}
.admin-edit .row-up:hover,.admin-edit .row-down:hover{background:var(--brand-soft)}
.admin-edit .bil-readonly{background:#f4f7f8;color:var(--muted);cursor:default;text-align:center}
.admin-topbar-meta .admin-hint{font-size:11px;color:var(--brand);opacity:.85}
.admin-edit table.data select{
  width:100%;max-width:280px;border:1px solid var(--line);background:#fff;font-size:12px;
  padding:5px 7px;border-radius:6px;font-family:inherit;color:var(--ink);cursor:pointer;
}
.admin-edit table.data select:focus{
  outline:none;border-color:var(--brand-2);background:#fff;box-shadow:0 0 0 2px var(--brand-soft);
}
@media(max-width:700px){
  .admin-topbar{flex-direction:column;align-items:stretch}
  .prof-pick-row select{max-width:none;width:100%}
  .admin-topbar-actions{margin-left:0;width:100%}
  .admin-topbar-actions .btn{flex:1}
}

.admin-edit table.data input,.admin-edit table.data select{
  width:100%;border:1px solid transparent;background:transparent;font-size:12.5px;
  padding:5px 7px;border-radius:6px;font-family:inherit;color:var(--ink);
}
.admin-edit table.data input:focus,.admin-edit table.data select:focus{
  outline:none;border-color:var(--brand-2);background:#fff;box-shadow:0 0 0 2px var(--brand-soft);
}
.admin-edit table.data td{padding:3px 4px}
.admin-edit .row-del{color:var(--red);cursor:pointer;font-weight:700;border:0;background:transparent;padding:4px 7px;border-radius:6px}
.admin-edit .row-del:hover{background:var(--red-soft)}
.admin-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.admin-toolbar .result-count{margin-left:auto}
.admin-dirty{font-size:12px;color:var(--amber);font-weight:700}

.src-note{
  font-size:12px;color:var(--ink-2);background:var(--brand-soft);
  border:1px solid #cfe8ed;border-radius:9px;padding:8px 12px;margin:-6px 0 16px;
}
tr.grp-row td{
  background:#eef3f8 !important;font-weight:800;color:var(--brand);
  text-transform:uppercase;letter-spacing:.4px;font-size:11.5px;
}
tr.grp-row:hover td{background:#e2eef4 !important}
