@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
:root{
  --red:#EB0A1E; --red-d:#c40818; --dark:#15171C; --dark2:#1d2026;
  --bg:#F5F6F8; --line:#E5E7EB; --ink:#15171C; --muted:#6b7280;
  --ok:#15803d; --okbg:#dcfce7; --warn:#b45309; --warnbg:#fef3c7; --rad:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14.5px}
a{color:var(--red);text-decoration:none}
img{max-width:100%}
.svgi{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;flex-shrink:0}

/* ---------- auth pages ---------- */
.auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 14px;background:linear-gradient(135deg,#0e0f13,#2a0306)}
.auth-card{background:#fff;border-radius:18px;padding:30px;width:100%;max-width:430px;box-shadow:0 24px 60px rgba(0,0,0,.3)}
.auth-card.wide{max-width:620px}
.auth-logo{text-align:center;margin-bottom:6px}
.auth-card h1{font-size:23px;margin:6px 0 2px;text-align:center}
.auth-card .lead{color:var(--muted);text-align:center;margin:0 0 18px;font-size:13.5px}
label{display:block;font-size:13px;font-weight:600;margin:13px 0 6px}
input,select,textarea{width:100%;padding:12px 13px;border:1px solid #cfd4dd;border-radius:11px;font-size:15px;font-family:inherit;min-height:44px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(235,10,30,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;background:var(--red);color:#fff;border:none;border-radius:11px;padding:12px 18px;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit}
.btn:hover{background:var(--red-d)} .btn.block{display:flex;width:100%}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.dark{background:var(--dark)} .btn.sm{min-height:38px;padding:9px 13px;font-size:13.5px}
.muted{color:var(--muted);font-size:13px} .center{text-align:center}
.alert{padding:12px 14px;border-radius:11px;margin-bottom:14px;font-size:13.5px}
.a-err{background:#fee2e2;color:#991b1b}.a-ok{background:var(--okbg);color:var(--ok)}.a-info{background:#e0f2fe;color:#075985}.a-warn{background:var(--warnbg);color:var(--warn)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hint{font-size:12px;color:var(--muted);margin-top:5px}

/* ---------- app shell ---------- */
.shell{display:flex;min-height:100vh}
.side{width:252px;background:var(--dark);color:#c7ccd6;flex-shrink:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.side .brand{display:flex;align-items:center;gap:9px;padding:18px;color:#fff;font-weight:800;border-bottom:1px solid #262a33}
.side .brand img{height:30px}
.side nav{padding:12px 10px;flex:1;overflow-y:auto}
.side a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;color:#c7ccd6;font-weight:600;margin-bottom:2px;min-height:44px}
.side a:hover{background:#23272f;color:#fff}
.side a.active{background:var(--red);color:#fff}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.top{display:flex;align-items:center;gap:12px;background:var(--dark);color:#fff;padding:12px 20px;position:sticky;top:0;z-index:20}
.top .burger{display:none;background:none;border:none;color:#fff;cursor:pointer}
.top .ttl{font-weight:700;flex:1}
.top .who{display:flex;align-items:center;gap:10px;font-size:13px}
.top .who img,.top .who .ava{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#374151;display:grid;place-items:center;font-weight:700;font-size:12px}
.content{padding:22px;max-width:1240px;width:100%}

.welcome{font-size:13px;color:var(--muted)} .welcome b{display:block;font-size:26px;color:var(--ink);margin-top:2px}
.subline{color:var(--muted);font-size:13px;margin-top:4px}

.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:18px 0}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:16px;display:flex;gap:12px;align-items:flex-start}
.kpi .ic{width:42px;height:42px;border-radius:11px;background:#fde7e9;color:var(--red);display:grid;place-items:center;flex-shrink:0}
.kpi small{color:var(--muted);font-size:12px;display:block}
.kpi b{font-size:18px;display:block;margin-top:3px}
.kpi .sub{font-size:11.5px;color:var(--muted);margin-top:2px}

.grid2{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--rad);padding:18px;margin-bottom:18px}
.card h3{margin:0 0 12px;font-size:16px}
.card .hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}

table{width:100%;border-collapse:collapse;font-size:13.5px}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}
.badge{display:inline-block;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}
.b-ok{background:var(--okbg);color:var(--ok)}.b-warn{background:var(--warnbg);color:var(--warn)}.b-red{background:#fee2e2;color:#991b1b}.b-info{background:#e0edff;color:#1e40af}

.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:16px;overflow-x:auto}
.tabs a{padding:11px 14px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;white-space:nowrap}
.tabs a.active{color:var(--red);border-color:var(--red)}
.kv{display:grid;grid-template-columns:170px 1fr;gap:8px 14px;font-size:14px}
.kv .k{color:var(--muted)} .kv .v{font-weight:600}

.profile-head{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.profile-head .pic,.profile-head .pic img{width:92px;height:92px;border-radius:14px;object-fit:cover}
.profile-head .pic{background:#e5e7eb;display:grid;place-items:center;font-weight:800;font-size:26px;color:#6b7280}
.profile-head h2{margin:0 0 4px} .profile-head .meta{color:var(--muted);font-size:13.5px}

.donut{--p:0;--c:var(--ok);width:120px;height:120px;border-radius:50%;display:grid;place-items:center;margin:0 auto;
  background:conic-gradient(var(--c) calc(var(--p)*3.6deg),#eceff3 0)}
.donut .in{width:92px;height:92px;border-radius:50%;background:#fff;display:grid;place-items:center;text-align:center}
.donut b{font-size:20px}.donut small{color:var(--muted);font-size:11px}

/* mobile bottom nav */
.botnav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);z-index:30}
.botnav a{flex:1;text-align:center;padding:8px 0;color:var(--muted);font-size:11px;display:flex;flex-direction:column;align-items:center;gap:3px;min-height:54px;justify-content:center}
.botnav a.active{color:var(--red)}

@media(max-width:960px){.cards{grid-template-columns:1fr 1fr}.grid2{grid-template-columns:1fr}}
@media(max-width:760px){
  .side{position:fixed;left:-260px;z-index:60;transition:left .25s} .shell.open .side{left:0}
  .top .burger{display:block} .content{padding:16px;padding-bottom:80px}
  .botnav{display:flex} .kv{grid-template-columns:1fr;gap:2px 0} .kv .k{margin-top:8px}
  /* responsive tables -> stacked cards */
  table.resp thead{display:none}
  table.resp tr{display:block;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;padding:6px 4px}
  table.resp td{display:flex;justify-content:space-between;border:none;white-space:normal;padding:7px 12px}
  table.resp td::before{content:attr(data-l);color:var(--muted);font-weight:600;margin-right:10px}
}
@media(max-width:430px){.cards{grid-template-columns:1fr}.row2{grid-template-columns:1fr}}

/* print (salary slip / statements) */
@media print{
  .noprint{display:none!important} body{background:#fff}
  .sheet{box-shadow:none;border:none;margin:0;max-width:100%}
}
.sheet{background:#fff;max-width:820px;margin:20px auto;border:1px solid var(--line);border-radius:10px;padding:0;overflow:hidden}
.sheet .ph{background:var(--dark);color:#fff;padding:18px 24px;display:flex;justify-content:space-between;align-items:center}
.sheet .pb{padding:24px}
.sheet .stitle{border-left:4px solid var(--red);padding-left:10px;font-weight:700;margin:18px 0 10px}
.sheet table td,.sheet table th{border-bottom:1px solid #eee;padding:8px 10px;white-space:normal}
.sheet .tot{font-weight:800}
.sheet .foot{border-top:1px solid var(--line);padding:14px 24px;color:var(--muted);font-size:12px}
