/* ── Reset & Variables ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --primary:#1a3a5c;--primary-dk:#112840;--primary-mid:#1e4570;
  --accent:#10b981;--accent-dk:#059669;
  --blue:#3b82f6;--blue-dk:#2563eb;
  --danger:#ef4444;--warning:#f59e0b;--info:#06b6d4;--purple:#8b5cf6;
  --teal:#14b8a6;--orange:#f97316;
  --text:#1f2937;--muted:#6b7280;--bg:#f1f5f9;--white:#fff;--border:#e2e8f0;
  --sh:0 1px 3px rgba(0,0,0,.10),0 1px 2px rgba(0,0,0,.06);
  --sh-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  --sh-lg:0 10px 25px rgba(0,0,0,.12),0 4px 6px rgba(0,0,0,.06);
  --sw:250px;--r:8px;--rs:5px;
}
html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:14px;color:var(--text);background:var(--bg);line-height:1.5}

/* ── Login ─────────────────────────────────────────────────────── */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f2744 0%,#1a3a5c 40%,#155e75 100%)}
.login-box{background:var(--white);border-radius:12px;padding:2.5rem 2.25rem;width:380px;box-shadow:var(--sh-lg)}
.login-logo{text-align:center;margin-bottom:2rem}
.login-logo h1{font-size:1.8rem;font-weight:800;color:var(--primary);letter-spacing:-.03em}
.login-logo h1 span{color:var(--accent)}
.login-logo p{color:var(--muted);font-size:.82rem;margin-top:.3rem}
.login-footer{text-align:center;color:var(--muted);font-size:.72rem;margin-top:1.5rem}

/* ── App Shell ─────────────────────────────────────────────────── */
#app{display:flex;height:100vh;overflow:hidden}

/* ── Sidebar ───────────────────────────────────────────────────── */
#sidebar{width:var(--sw);background:var(--primary);color:#fff;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}
.sidebar-brand{padding:1.1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}
.brand-name{font-size:1.2rem;font-weight:800;letter-spacing:-.02em;color:#fff}
.brand-name span{color:var(--accent)}
.brand-tag{font-size:.58rem;color:rgba(255,255,255,.4);margin-top:.1rem}
#sidebar-nav{flex:1;padding:.5rem 0 1rem}
.nav-section{padding:.75rem 1.25rem .2rem;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35)}
.nav-item{display:flex;align-items:center;gap:.55rem;padding:.45rem 1.25rem;color:rgba(255,255,255,.75);text-decoration:none;font-size:.81rem;transition:background .12s,color .12s}
.nav-item:hover{background:rgba(255,255,255,.09);color:#fff}
.nav-item.active{background:var(--accent);color:#fff;font-weight:600}
.ni{font-size:.9rem;width:1rem;text-align:center;flex-shrink:0}
.sidebar-footer{padding:.875rem 1.25rem;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}
.sf-name{font-size:.8rem;font-weight:600;color:rgba(255,255,255,.9)}
.sf-role{font-size:.68rem;color:rgba(255,255,255,.45);margin-bottom:.6rem;text-transform:capitalize}
.btn-logout{display:block;width:100%;background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.15);border-radius:var(--rs);padding:.4rem;font-size:.75rem;cursor:pointer;transition:background .12s;text-align:center}
.btn-logout:hover{background:rgba(255,255,255,.2);color:#fff}

/* ── Main ──────────────────────────────────────────────────────── */
#main{flex:1;overflow-y:auto;min-width:0;display:flex;flex-direction:column}
#page-content{flex:1}

/* ── Page Header ───────────────────────────────────────────────── */
.ph{display:flex;align-items:flex-start;justify-content:space-between;padding:1.375rem 1.75rem .875rem;background:var(--white);border-bottom:1px solid var(--border);gap:1rem}
.ph h2{font-size:1.25rem;font-weight:700;color:var(--primary);letter-spacing:-.02em}
.ph p{font-size:.75rem;color:var(--muted);margin-top:.2rem}
.ph-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}

/* ── KPI Grid ──────────────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.875rem;padding:1.25rem 1.75rem}
.kpi{background:var(--white);border-radius:var(--r);box-shadow:var(--sh);padding:1rem 1.1rem;border-left:4px solid var(--blue)}
.kpi.accent{border-color:var(--accent)}.kpi.warn{border-color:var(--warning)}.kpi.danger{border-color:var(--danger)}
.kpi.purple{border-color:var(--purple)}.kpi.info{border-color:var(--info)}.kpi.teal{border-color:var(--teal)}.kpi.orange{border-color:var(--orange)}
.kpi-lbl{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.kpi-val{font-size:1.5rem;font-weight:800;color:var(--primary);line-height:1.1;margin:.2rem 0}
.kpi-sub{font-size:.68rem;color:var(--muted)}

/* ── Cards ─────────────────────────────────────────────────────── */
.card{background:var(--white);border-radius:var(--r);box-shadow:var(--sh)}
.card-hd{padding:.875rem 1.1rem .7rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:.71rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.card-bd{padding:1.1rem}

/* ── Grids ─────────────────────────────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:0 1.75rem 1.75rem}
.g3{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:0 1.75rem 1.75rem}
.g4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.875rem;padding:0 1.75rem 1.75rem}
.pad{padding:1.75rem}.pad-x{padding:0 1.75rem}.pad-b{padding-bottom:1.75rem}
.gap-sm{gap:.5rem}

/* ── Tables ────────────────────────────────────────────────────── */
.tb-wrap{padding:0 1.75rem 1.75rem}
.tb-bar{display:flex;gap:.6rem;align-items:center;padding:1rem 1.75rem .75rem;flex-wrap:wrap}
.tb-card{background:var(--white);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{background:#f8fafc;padding:.55rem .85rem;text-align:left;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap}
tbody td{padding:.6rem .85rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;font-size:.82rem}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#f8fafc}
.no-data{text-align:center;padding:3rem 1rem;color:var(--muted);font-size:.85rem}
.ra{display:flex;gap:.3rem;justify-content:flex-end}
.num{font-family:Consolas,monospace;font-size:.8rem}
.mono{font-family:Consolas,monospace;font-size:.78rem}

/* ── Buttons ───────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:var(--rs);border:1px solid transparent;font-size:.81rem;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap;line-height:1;font-family:inherit}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-p{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-p:hover{background:var(--blue-dk);border-color:var(--blue-dk)}
.btn-s{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-s:hover{background:var(--accent-dk)}
.btn-d{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-d:hover{filter:brightness(.9)}
.btn-w{background:var(--warning);color:#fff;border-color:var(--warning)}.btn-w:hover{filter:brightness(.9)}
.btn-o{background:var(--white);color:var(--text);border-color:var(--border)}.btn-o:hover{background:var(--bg)}
.btn-info{background:var(--info);color:#fff;border-color:var(--info)}.btn-info:hover{filter:brightness(.9)}
.btn-purple{background:var(--purple);color:#fff;border-color:var(--purple)}.btn-purple:hover{filter:brightness(.9)}
.btn-sm{padding:.3rem .6rem;font-size:.73rem}
.btn-xs{padding:.2rem .45rem;font-size:.68rem}
.btn-full{width:100%;justify-content:center}

/* ── Forms ─────────────────────────────────────────────────────── */
.f{margin-bottom:.875rem}
.f label{display:block;font-size:.73rem;font-weight:600;color:var(--text);margin-bottom:.28rem}
.f input,.f select,.f textarea{width:100%;padding:.5rem .72rem;border:1px solid var(--border);border-radius:var(--rs);font-size:.82rem;color:var(--text);background:var(--white);transition:border-color .12s,box-shadow .12s;font-family:inherit}
.f input:focus,.f select:focus,.f textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.f textarea{resize:vertical;min-height:70px}
.f input[readonly]{background:#f8fafc;color:var(--muted)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}
.fr4{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}

/* ── Badges ────────────────────────────────────────────────────── */
.badge{display:inline-block;padding:.16rem .5rem;border-radius:999px;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.b-active,.b-approved,.b-completed,.b-paid,.b-present,.b-acknowledged,.b-hired{background:#d1fae5;color:#065f46}
.b-pending,.b-draft,.b-scheduled,.b-applied,.b-open,.b-in_progress,.b-enrolled{background:#fef3c7;color:#78350f}
.b-inactive,.b-cancelled,.b-disposed,.b-closed,.b-rejected,.b-withdrawn,.b-terminated{background:#f1f5f9;color:#475569}
.b-processing,.b-investigating,.b-screening,.b-ongoing{background:#dbeafe;color:#1e40af}
.b-overdue,.b-absent,.b-critical,.b-poor{background:#fee2e2;color:#991b1b}
.b-late,.b-half_day,.b-on_leave,.b-interview,.b-offer{background:#ede9fe;color:#5b21b6}
.b-full_time{background:#d1fae5;color:#065f46}
.b-part_time,.b-contract{background:#fef3c7;color:#78350f}
.b-excellent,.b-good{background:#d1fae5;color:#065f46}
.b-average{background:#fef3c7;color:#78350f}
.b-male{background:#dbeafe;color:#1e40af}
.b-female{background:#fce7f3;color:#9d174d}
.b-internal{background:#dbeafe;color:#1e40af}
.b-external{background:#ede9fe;color:#5b21b6}
.b-online{background:#d1fae5;color:#065f46}
.b-health{background:#fee2e2;color:#991b1b}
.b-pension{background:#dbeafe;color:#1e40af}
.b-life_insurance{background:#fef3c7;color:#78350f}

/* ── Modal ─────────────────────────────────────────────────────── */
#modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}
#modal-box{background:var(--white);border-radius:var(--r);box-shadow:var(--sh-lg);width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;animation:mIn .18s ease}
#modal-box.wide{max-width:820px}#modal-box.narrow{max-width:420px}#modal-box.x-wide{max-width:1000px}
@keyframes mIn{from{transform:scale(.96) translateY(-8px);opacity:0}to{transform:none;opacity:1}}
#modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.375rem;border-bottom:1px solid var(--border);flex-shrink:0}
#modal-title{font-size:.93rem;font-weight:700;color:var(--primary)}
#modal-close{background:none;border:none;font-size:1.35rem;cursor:pointer;color:var(--muted);line-height:1;padding:.15rem .4rem;border-radius:var(--rs);transition:all .12s}
#modal-close:hover{background:#fee2e2;color:var(--danger)}
#modal-body{padding:1.375rem;overflow-y:auto;flex:1}
.ma{display:flex;gap:.5rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border);margin-top:1rem;flex-wrap:wrap}

/* ── Toast ─────────────────────────────────────────────────────── */
#toast-container{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}
.toast{background:var(--white);border-radius:var(--rs);box-shadow:var(--sh-lg);padding:.7rem 1.1rem;font-size:.82rem;font-weight:500;border-left:3px solid var(--accent);animation:tIn .2s ease;min-width:200px;pointer-events:all}
.te{border-color:var(--danger)}.tw{border-color:var(--warning)}.ti{border-color:var(--blue)}
@keyframes tIn{from{transform:translateX(120%);opacity:0}to{transform:none;opacity:1}}

/* ── Misc ──────────────────────────────────────────────────────── */
.tr{text-align:right}.tc{text-align:center}.tm{color:var(--muted)}.tg{color:var(--accent-dk)}.tr2{color:var(--danger)}.tb2{color:var(--blue-dk)}
.fw7{font-weight:700}.fs-sm{font-size:.75rem}.fs-xs{font-size:.68rem}
.err{background:#fef2f2;color:var(--danger);padding:.55rem .85rem;border-radius:var(--rs);font-size:.8rem;margin-bottom:.75rem;border:1px solid #fecaca}
.loading-state{text-align:center;padding:2.5rem 1rem;color:var(--muted);font-size:.85rem}
.divider{border:none;border-top:1px solid var(--border);margin:.875rem 0}
.info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--rs);padding:.75rem 1rem;font-size:.8rem;color:#1e40af;margin-bottom:.875rem}

/* ── Bar Chart ─────────────────────────────────────────────────── */
.bar-chart{display:flex;flex-direction:column;gap:.65rem}
.bar-row{display:flex;align-items:center;gap:.75rem}
.bar-lbl{font-size:.75rem;min-width:120px;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.bar-track{flex:1;height:8px;background:var(--bg);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:var(--blue);transition:width .5s ease}
.bar-fill.a{background:var(--accent)}.bar-fill.d{background:var(--danger)}.bar-fill.w{background:var(--warning)}.bar-fill.p{background:var(--purple)}.bar-fill.t{background:var(--teal)}
.bar-val{font-size:.72rem;min-width:70px;text-align:right;color:var(--muted)}

/* ── Tabs ──────────────────────────────────────────────────────── */
.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:1.25rem}
.tab{padding:.55rem 1rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.81rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .12s;font-family:inherit;white-space:nowrap}
.tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.tab:hover:not(.active){color:var(--text)}

/* ── Detail Grid ───────────────────────────────────────────────── */
.dg{display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1.25rem}
.dg3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.6rem 1rem}
.dr{display:flex;flex-direction:column;gap:.12rem}
.dl{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.dv{font-size:.86rem;color:var(--text)}

/* ── Alerts ────────────────────────────────────────────────────── */
.alert{padding:.65rem 1rem;border-radius:var(--rs);font-size:.81rem;margin-bottom:.75rem}
.alert-w{background:#fef3c7;color:#78350f;border:1px solid #fde68a}
.alert-i{background:#dbeafe;color:#1e3a8a;border:1px solid #bfdbfe}
.alert-s{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.alert-d{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}

/* ── Avatar ────────────────────────────────────────────────────── */
.avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--primary);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.78rem;font-weight:700;flex-shrink:0;border:2px solid var(--border);overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar-lg{width:88px;height:88px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0;border:3px solid var(--border);overflow:hidden}
.avatar-lg img{width:100%;height:100%;object-fit:cover}
.emp-row{display:flex;align-items:center;gap:.75rem}

/* ── Progress ──────────────────────────────────────────────────── */
.progress{height:6px;background:var(--bg);border-radius:999px;overflow:hidden;margin-top:.25rem}
.progress-fill{height:100%;border-radius:999px;background:var(--accent);transition:width .4s ease}
.progress-fill.warn{background:var(--warning)}.progress-fill.danger{background:var(--danger)}

/* ── Stat Row ──────────────────────────────────────────────────── */
.stat-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:1px solid #f1f5f9}
.stat-row:last-child{border-bottom:none}
.stat-label{font-size:.78rem;color:var(--muted)}
.stat-value{font-size:.82rem;font-weight:700;color:var(--text)}

/* ── Org Chart ─────────────────────────────────────────────────── */
.org-node{background:var(--white);border:2px solid var(--border);border-radius:var(--r);padding:.7rem 1rem;text-align:center;min-width:140px;box-shadow:var(--sh);cursor:pointer;transition:border-color .15s}
.org-node:hover{border-color:var(--accent)}
.org-node .on-name{font-size:.8rem;font-weight:700;color:var(--primary)}
.org-node .on-pos{font-size:.68rem;color:var(--muted);margin-top:.1rem}
.org-node .on-dept{font-size:.65rem;color:var(--accent);font-weight:600}

/* ── Photo Upload ─────────────────────────────────────────────── */
.photo-drop{border:2px dashed var(--border);border-radius:var(--r);padding:1.5rem;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--bg)}
.photo-drop:hover,.photo-drop.drag{border-color:var(--blue);background:#eff6ff}
.photo-drop p{font-size:.78rem;color:var(--muted);margin-top:.35rem}
.photo-preview{position:relative;display:inline-block}
.photo-preview img{width:120px;height:120px;object-fit:cover;border-radius:var(--r);border:2px solid var(--border)}
.photo-preview .rm-photo{position:absolute;top:-6px;right:-6px;background:var(--danger);color:#fff;border:none;border-radius:50%;width:20px;height:20px;cursor:pointer;font-size:.75rem;line-height:1;display:flex;align-items:center;justify-content:center}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}
.photo-card{background:var(--white);border-radius:var(--r);box-shadow:var(--sh);padding:.875rem;text-align:center;border:2px solid var(--border);transition:border-color .15s}
.photo-card:hover{border-color:var(--accent)}
.photo-card .pc-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;font-weight:700;margin:0 auto .6rem;overflow:hidden;border:2px solid var(--border)}
.photo-card .pc-avatar img{width:100%;height:100%;object-fit:cover}
.photo-card .pc-name{font-size:.78rem;font-weight:700;color:var(--primary);margin-bottom:.2rem}
.photo-card .pc-role{font-size:.68rem;color:var(--muted);margin-bottom:.6rem}

/* ── Mobile Topbar & Overlay ──────────────────────────────────── */
#mobile-bar{display:none;align-items:center;gap:.75rem;padding:.6rem 1rem;background:var(--primary);position:fixed;top:0;left:0;right:0;z-index:200;height:52px;flex-shrink:0}
.hamburger{background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;padding:.2rem .4rem;line-height:1;border-radius:var(--rs);transition:background .12s}
.hamburger:hover{background:rgba(255,255,255,.15)}
.m-brand{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;color:#fff}
.m-brand span{color:var(--accent)}
#sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:250;cursor:pointer}
#sidebar-overlay.open{display:block}

/* ── Responsive ≤768px ────────────────────────────────────────── */
@media(max-width:768px){
  #app{flex-direction:column}
  #mobile-bar{display:flex}
  #main{padding-top:52px}
  #sidebar{position:fixed;top:0;left:0;bottom:0;z-index:300;width:270px;transform:translateX(-100%);transition:transform .25s ease}
  #sidebar.open{transform:translateX(0)}
  .login-box{width:calc(100% - 2rem);padding:1.75rem 1.25rem}
  .ph{flex-direction:column;padding:.875rem 1rem .75rem;gap:.6rem}
  .ph-actions{width:100%;flex-wrap:wrap}
  .g2,.g3,.g4{grid-template-columns:1fr;padding:0 1rem 1rem}
  .kpi-grid{padding:.875rem 1rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .dg,.dg3{grid-template-columns:1fr}
  .fr,.fr3,.fr4{grid-template-columns:1fr}
  .tb-wrap{padding:0 1rem 1rem}
  .tb-bar{padding:.75rem 1rem .6rem}
  .tb-card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .pad{padding:1rem}.pad-x{padding:0 1rem}.pad-b{padding-bottom:1rem}
  #modal-overlay{padding:0;align-items:flex-end}
  #modal-box,#modal-box.wide,#modal-box.x-wide,#modal-box.narrow{max-width:100%;border-radius:12px 12px 0 0;max-height:88vh}
  #modal-header{padding:.75rem 1rem}
  #modal-body{padding:1rem}
  .btn{min-height:36px}
  .btn-sm{padding:.4rem .65rem;min-height:32px}
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}
  .bar-lbl{min-width:85px;max-width:85px}
  #toast-container{top:auto;bottom:1rem;right:.75rem;left:.75rem}
  .toast{min-width:unset;width:100%}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .ph h2{font-size:1.05rem}
}
