:root {
  --bg: #f5f6f8;
  --bg-soft: #fafbfc;
  --card: #ffffff;
  --card-hover: #f8fafc;
  --ink: #1c2534;
  --muted: #67748b;
  --line: #e4e8ee;
  --accent: #e8552f;        /* warm coral — human touch */
  --accent-soft: rgba(232, 85, 47, .1);
  --blue: #2f6fd6;
  --good: #0e9b64;
  --ok: #c77d0a;
  --bad: #d43d55;
  --vbad: #b91c1c;
  --radius: 12px;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font: 14px/1.55 "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--blue); text-decoration: none; }
a:hover { color: #1e56b0; }
h1, h2, .brand, .kpi-value, .login-card h1 {
  font-family: "Space Grotesk", "Inter", sans-serif; letter-spacing: -.01em;
}
h1 { font-size: 24px; margin: 0; font-weight: 700; }
h1 .muted { font-size: 13px; font-weight: 400; font-family: "Inter", sans-serif; }
h2 { font-size: 13px; margin: 28px 0 10px; font-weight: 700; text-transform: uppercase;
     letter-spacing: .07em; color: var(--muted); }
.muted { color: var(--muted); }
.small { font-size: 12px; }
code.pw { background: var(--accent); color: #fff; padding: 2px 10px; border-radius: 6px;
          font-size: 15px; font-weight: 700; }

.topbar { background: #fff; border-bottom: 1px solid var(--line);
          position: sticky; top: 0; z-index: 10; }
.topbar-inner {
  max-width: 1320px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; gap: 30px; height: 58px;
}
.brand { color: var(--ink); font-weight: 700; font-size: 17px; }
.brand span { color: var(--accent); font-weight: 400; }
.brand:hover { color: var(--ink); }
.topbar nav { display: flex; gap: 2px; flex: 1; }
.topbar nav a {
  color: var(--muted); padding: 7px 14px; border-radius: 999px; font-weight: 500; font-size: 13.5px;
}
.topbar nav a:hover { color: var(--ink); }
.topbar nav a.active { color: var(--accent); background: var(--accent-soft); font-weight: 600; }
.whoami { display: flex; gap: 16px; align-items: center; color: var(--muted); font-size: 13px; }
.whoami em { font-style: normal; opacity: .8; }
.whoami a { color: var(--ink); font-weight: 500; }

.viewas-banner {
  background: #fdf3e3; border-bottom: 1px solid #f0d9a8; color: #7c5308;
  padding: 8px 24px; text-align: center; font-size: 13px;
}
.viewas-banner a { font-weight: 700; color: var(--accent); margin-left: 8px; }
.viewas-btn {
  display: inline-block; font-size: 12px; font-weight: 600; padding: 4px 12px;
  border: 1px solid var(--line); border-radius: 999px; vertical-align: middle; margin-left: 8px;
}
.viewas-btn:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }

.container { max-width: 1320px; margin: 28px auto 70px; padding: 0 24px; }
.page-head { display: flex; justify-content: space-between; align-items: center; gap: 16px;
             flex-wrap: wrap; margin-bottom: 22px; }
.crumb { font-weight: 400; color: var(--muted); }
.crumb:hover { color: var(--blue); }

.daterange-wrap { display: flex; flex-direction: column; gap: 8px; align-items: flex-end; }
.daterange { display: flex; gap: 10px; align-items: end; }
.daterange label { font-size: 11px; color: var(--muted); display: flex; flex-direction: column;
                   gap: 4px; text-transform: uppercase; letter-spacing: .05em; }
.presets { display: flex; gap: 4px; flex-wrap: wrap; justify-content: flex-end; }
.presets button {
  font-size: 12px; font-weight: 500; padding: 4px 11px; border-radius: 999px;
  background: #fff; border: 1px solid var(--line); color: var(--muted);
}
.presets button:hover { color: var(--accent); border-color: var(--accent); }
.presets button.active {
  background: var(--accent-soft); border-color: var(--accent); color: var(--accent);
  font-weight: 600;
}
@media (max-width: 900px) { .daterange-wrap { align-items: flex-start; } }

.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
        gap: 14px; margin-bottom: 18px; }
.kpi {
  background: var(--card);
  border: 1px solid var(--line); border-radius: var(--radius);
  padding: 14px 18px; position: relative; overflow: hidden;
  box-shadow: 0 1px 2px rgba(16, 24, 40, .04);
}
.kpi::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px;
               background: var(--line); }
.kpi-good::before { background: var(--good); }
.kpi-ok::before { background: var(--ok); }
.kpi-bad::before { background: var(--bad); }
.kpi-vbad::before { background: var(--vbad); }
.kpi-warn::before { background: var(--accent); }
.kpi-label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.kpi-value { font-size: 30px; font-weight: 700; margin: 3px 0 1px; }
.kpi-value small { font-size: 15px; color: var(--muted); font-weight: 400; }
.kpi-sub { font-size: 12px; color: var(--muted); }
.kpi-sub a { color: var(--accent); }

.card {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 18px; margin-bottom: 16px; overflow-x: auto;
  box-shadow: 0 1px 2px rgba(16, 24, 40, .04);
}
.card.narrow { max-width: 580px; }
.chart-card { padding: 14px 18px; }

table.data { width: 100%; border-collapse: collapse; }
table.data th {
  text-align: left; font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted); padding: 7px 10px; border-bottom: 1px solid var(--line);
}
table.data td { padding: 9px 10px; border-bottom: 1px solid #eef1f5; vertical-align: top; }
table.data tr:last-child td { border-bottom: none; }
table.data tbody tr:hover { background: var(--card-hover); }
table.data td .muted { display: block; font-size: 12px; }
table.data td a strong { color: var(--ink); }
table.data td a:hover strong { color: var(--blue); }
th.num, td.num { text-align: right; font-variant-numeric: tabular-nums; }
td.bad { color: var(--bad); font-weight: 600; }
td.good { color: var(--good); font-weight: 600; }
td.warn { color: var(--ok); font-weight: 600; }
td.band-good { color: var(--good); font-weight: 600; }
td.band-ok { color: var(--ok); font-weight: 600; }
td.band-bad { color: var(--bad); font-weight: 600; }
td.band-vbad { color: var(--vbad); font-weight: 700; }
tr.row-flagged { background: #fdf5f6; }
tr.row-nodata { background: #fdf9ef; }
tr.row-flagged:hover, tr.row-nodata:hover { background: #faf1f2; }

.badge {
  display: inline-block; font-size: 11px; font-weight: 600; padding: 2.5px 9px;
  border-radius: 999px; margin: 1px 3px 1px 0; white-space: nowrap;
}
.badge-hours { background: #fceef0; color: var(--bad); }
.badge-efficiency { background: #fdf3e3; color: var(--ok); }
.badge-errors { background: #f5eefd; color: #8b3fd1; }
.badge-ok { background: #e7f6ef; color: var(--good); }
.badge-due { background: var(--vbad); color: #fff; }
.badge-mark { background: #d97706; color: #fff; }
.badge-leave { background: #e9f0fb; color: var(--blue); }
.badge-holiday { background: #ede9fe; color: #6d28d9; }
.badge-kind { background: var(--accent-soft); color: var(--accent); text-transform: uppercase; }

.alert { padding: 11px 15px; border-radius: 10px; margin-bottom: 12px; border: 1px solid; }
.alert-error { background: #fdecec; color: #a52222; border-color: #f5c6c6; }
.alert-ok { background: #e7f6ef; color: #10613f; border-color: #bfe6d2; }

form.stacked { display: flex; flex-direction: column; gap: 14px; }
form.stacked label { display: flex; flex-direction: column; gap: 5px; font-weight: 600; font-size: 13px; }
form.stacked .muted { font-weight: 400; }
input[type=text], input[type=email], input[type=password], input[type=date],
input[type=number], input[type=file], select, textarea {
  font: inherit; padding: 8px 12px; border: 1px solid #cdd5e0; border-radius: 9px;
  background: #fff; color: var(--ink);
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); }
textarea { resize: vertical; }
::placeholder { color: #9aa5b8; }
button {
  font: inherit; font-weight: 600; padding: 8px 16px; border-radius: 9px;
  border: 1px solid #cdd5e0; background: #fff; color: var(--ink); cursor: pointer;
}
button:hover { border-color: var(--accent); color: var(--accent); }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-primary:hover { background: #d2431f; border-color: #d2431f; color: #fff; }
.btn-block { width: 100%; }
.btn-small { font-size: 12px; padding: 4px 11px; }
.btn-link { border: none; background: none; padding: 0 4px; color: var(--muted); }
.btn-link:hover { color: var(--bad); border: none; }
form.inline { display: inline-flex; gap: 6px; align-items: center; }
form.statusform select, form.statusform input { font-size: 12px; padding: 4px 8px; }
form.reviewform { width: 100%; margin-top: 10px; }
form.reviewform input { flex: 1; }

.two-col { display: grid; grid-template-columns: 3fr 2fr; gap: 26px; align-items: start; }
@media (max-width: 1000px) { .two-col { grid-template-columns: 1fr; } }

.error-card { border-left: 3px solid var(--bad); }
.error-card.reviewed { border-left-color: var(--good); opacity: .8; }
.error-head { display: flex; gap: 10px; align-items: baseline; flex-wrap: wrap; margin-bottom: 10px; }
.error-cat { font-size: 12px; color: #8b3fd1; font-weight: 600; }
.diff { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 700px) { .diff { grid-template-columns: 1fr; } }
.diff label, .disc-card label {
  display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted); font-weight: 700; margin-bottom: 3px;
}
.diff-was, .diff-now { padding: 9px 12px; border-radius: 9px; font-size: 13px; }
.diff-was { background: #fdf1f2; border: 1px solid #f7d7db; }
.diff-now { background: #eefaf3; border: 1px solid #cceedd; }

.disc-card p { margin: 10px 0 0; }
.disc-head { display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.action-plan { background: var(--accent-soft); border-radius: 9px; padding: 9px 12px; }
.pending-item { margin-bottom: 3px; }
.bar { background: #eef1f5; border-radius: 99px; height: 8px; overflow: hidden; margin-top: 5px; }
.bar span { display: block; height: 100%; background: var(--accent); border-radius: 99px; }
.view-toggle-row { display: flex; align-items: center; gap: 8px; margin: 4px 0 14px; }
table.matrix th a, table.matrix td a { font-weight: 600; }
table.matrix tbody th { text-align: left; font-size: 13px; padding: 9px 10px; }
table.matrix tbody th a { color: var(--ink); text-transform: capitalize; }
table.matrix thead th a { color: var(--muted); text-transform: capitalize; }
table.matrix thead th a:hover, table.matrix tbody th a:hover { color: var(--accent); }
table.matrix .total-col { background: var(--bg-soft); }
table.matrix .totals-row td, table.matrix .totals-row th { border-top: 2px solid var(--line); }
table.matrix td.cell-selected { background: var(--accent-soft); border-radius: 6px; }
table.matrix a.selcell { color: var(--accent); }
.ext-link { font-size: 12px; font-weight: 600; white-space: nowrap; }
body.rate-mode .col-count { display: none; }
body:not(.rate-mode) .col-rate { display: none; }
.footnote { font-size: 12px; }
.upload-help { margin-top: 16px; font-size: 13px; color: var(--muted); }
.upload-help strong { color: var(--ink); }
.upload-help ul { margin: 6px 0; padding-left: 20px; }
.upload-help code { background: var(--bg); padding: 1px 6px; border-radius: 5px; font-size: 12px; }

.login-body {
  display: grid; place-items: center; min-height: 100vh; background: var(--bg);
  background-image: radial-gradient(ellipse 60% 45% at 50% -5%, rgba(232, 85, 47, .08), transparent),
                    radial-gradient(ellipse 45% 35% at 85% 110%, rgba(47, 111, 214, .07), transparent);
}
.login-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 16px;
  padding: 38px 42px; width: 380px;
  box-shadow: 0 12px 40px rgba(16, 24, 40, .1);
}
.login-card h1 { font-size: 26px; color: var(--ink); }
.login-card h1 span { color: var(--accent); font-weight: 400; }
.login-card p { margin-top: 4px; }
.login-card form { display: flex; flex-direction: column; gap: 15px; margin-top: 22px; }
.login-card label { display: flex; flex-direction: column; gap: 5px; font-weight: 600; font-size: 13px; }
