/* =====================================================================
   ELODIZ Internal HR - stylesheet
   Calm, utilitarian, high-legibility. No external dependencies
   (works with a strict self-only Content-Security-Policy).
   ===================================================================== */

:root{
  --ink:#1c2530;
  --ink-soft:#5b6675;
  --line:#e3e7ec;
  --bg:#f4f6f8;
  --card:#ffffff;
  --accent:#0b6b5b;          /* deep teal */
  --accent-dark:#085044;
  --warn:#9a3a12;
  --ok:#0b6b5b;
  --bad:#a51d2d;
  --radius:10px;
  --shadow:0 1px 2px rgba(20,30,45,.05),0 6px 22px rgba(20,30,45,.06);
  --mono:"SFMono-Regular",ui-monospace,"Cascadia Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- top bar ----------------------------------------------------- */
.topbar{
  display:flex;align-items:center;gap:28px;
  padding:0 26px;height:60px;
  background:var(--ink);color:#fff;
}
.brand a{color:#fff;font-weight:700;letter-spacing:.5px;font-size:18px}
.brand span{color:#7fd4c4;font-weight:600}
.mainnav{display:flex;gap:4px;flex:1;flex-wrap:wrap}
.mainnav a{
  color:#cdd5df;padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;
}
.mainnav a:hover{background:rgba(255,255,255,.08);color:#fff;text-decoration:none}
.navsep{width:1px;align-self:stretch;background:rgba(255,255,255,.15);margin:10px 6px}
.userbox{display:flex;align-items:center;gap:14px;font-size:14px}
.uname{color:#cdd5df}
.logout{color:#fff;border:1px solid rgba(255,255,255,.25);padding:6px 12px;border-radius:6px}
.logout:hover{background:rgba(255,255,255,.1);text-decoration:none}

/* ---- layout ------------------------------------------------------ */
.wrap{max-width:1080px;margin:34px auto;padding:0 24px}
.foot{
  text-align:center;color:var(--ink-soft);font-size:12.5px;
  padding:32px 0 40px;
}
h1{font-size:24px;margin:0 0 4px;font-weight:700;letter-spacing:-.2px}
h2{font-size:17px;margin:0 0 14px;font-weight:700}
.sub{color:var(--ink-soft);margin:0 0 26px;font-size:14px}

/* ---- cards & grid ------------------------------------------------ */
.grid{display:grid;gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}

.card{
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);
  padding:22px 24px;margin-bottom:22px;
}
.stat{font-size:34px;font-weight:700;letter-spacing:-1px;color:var(--ink)}
.stat small{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);
  letter-spacing:.3px;text-transform:uppercase;margin-bottom:8px}
.stat.accent{color:var(--accent)}

/* ---- tables ------------------------------------------------------ */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-soft)}
tbody tr:hover{background:#fafbfc}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}

/* ---- badges ------------------------------------------------------ */
.badge{display:inline-block;padding:3px 9px;border-radius:999px;
  font-size:12px;font-weight:600;border:1px solid transparent}
.b-pending{background:#fff4e5;color:#9a5a12;border-color:#f4d9b0}
.b-approved{background:#e6f4f1;color:var(--ok);border-color:#bfe3db}
.b-rejected,.b-cancelled{background:#fbe9eb;color:var(--bad);border-color:#f0c4c9}
.b-submitted{background:#eef1f5;color:#41506a;border-color:#d8dee8}

/* ---- forms ------------------------------------------------------- */
label{display:block;font-size:13px;font-weight:600;margin:0 0 6px;color:var(--ink)}
input,select,textarea{
  width:100%;font:inherit;color:var(--ink);background:#fff;
  border:1px solid #cdd4dd;border-radius:8px;padding:10px 12px;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(11,107,91,.15)}
textarea{min-height:84px;resize:vertical}
.field{margin-bottom:16px}
.row{display:flex;gap:16px;flex-wrap:wrap}
.row .field{flex:1;min-width:180px}

.btn{
  display:inline-block;cursor:pointer;font:inherit;font-weight:600;
  background:var(--accent);color:#fff;border:none;border-radius:8px;
  padding:10px 18px;
}
.btn:hover{background:var(--accent-dark);text-decoration:none}
.btn.sec{background:#eef1f5;color:var(--ink)}
.btn.sec:hover{background:#e2e7ee}
.btn.danger{background:var(--bad)}
.btn.danger:hover{background:#85121f}
.btn.sm{padding:6px 12px;font-size:13px}
.inline-form{display:inline}

/* ---- flash & auth ----------------------------------------------- */
.flash{background:#e6f4f1;border:1px solid #bfe3db;color:var(--accent-dark);
  padding:12px 16px;border-radius:8px;margin-bottom:22px;font-size:14px}
.error{background:#fbe9eb;border:1px solid #f0c4c9;color:var(--bad);
  padding:12px 16px;border-radius:8px;margin-bottom:18px;font-size:14px}

.authpage{display:flex;align-items:center;justify-content:center;
  min-height:100vh;background:var(--ink)}
.authcard{background:#fff;width:380px;max-width:92vw;border-radius:14px;
  padding:38px 34px;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.authcard h1{text-align:center;font-size:22px}
.authcard .logo{text-align:center;font-weight:700;font-size:20px;
  letter-spacing:.5px;margin-bottom:6px}
.authcard .logo span{color:var(--accent)}
.authcard .sub{text-align:center}
.authcard .btn{width:100%;padding:12px;margin-top:6px}
.muted{color:var(--ink-soft);font-size:13px}
.right{text-align:right}
.mt{margin-top:18px}
.tag{font-family:var(--mono);font-size:12px;background:#eef1f5;
  padding:2px 6px;border-radius:4px}
