:root{
  --bg:#f4f6f9; --panel:#ffffff; --ink:#1c2530; --mut:#6b7787;
  --line:#e2e7ee; --accent:#1f6f54; --accent-ink:#fff; --danger:#b3261e;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font:15px/1.55 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* top bar */
.topbar{display:flex;align-items:center;gap:22px;padding:0 22px;height:58px;
  background:var(--panel);border-bottom:1px solid var(--line)}
.brand{font-weight:700;letter-spacing:.2px}
.brand .advisory{font-size:11px;font-weight:600;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--accent);border-radius:999px;
  padding:1px 8px;margin-left:6px;vertical-align:middle}
.topbar nav{display:flex;gap:16px}
.topbar nav a{color:var(--mut);font-weight:600;font-size:14px}
.topbar .user{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:13px}
.topbar .email{color:var(--mut)}
.role{font-size:11px;font-weight:700;text-transform:uppercase;border-radius:999px;padding:2px 9px}
.role-admin{background:#e6f0ec;color:var(--accent)}
.role-employee{background:#eef1f6;color:#4a5666}
.logout{color:var(--mut);font-weight:600}

.wrap{max-width:920px;margin:0 auto;padding:28px 22px}
h1{font-size:24px;margin:0 0 18px}
h2{font-size:16px;margin:28px 0 10px;color:var(--mut);
  text-transform:uppercase;letter-spacing:.05em;font-weight:700}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.card-label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--mut);font-weight:700}
.card-value{font-size:26px;font-weight:700;margin:6px 0 2px}
.card-sub{font-size:13px;color:var(--mut)}

.checklist{list-style:none;padding:0;margin:0;max-width:520px}
.checklist li{background:var(--panel);border:1px solid var(--line);border-radius:9px;
  padding:9px 14px;margin-bottom:8px;color:var(--mut)}
.checklist li.done{color:var(--ink)}
.checklist li.done::before{content:"✓ ";color:var(--accent);font-weight:800}
.checklist li:not(.done)::before{content:"○ ";color:var(--mut)}

.note{color:var(--mut);font-size:13.5px;margin-top:22px;
  border-left:3px solid var(--line);padding:4px 0 4px 12px}

/* login */
.login-page{display:grid;place-items:center;min-height:100vh}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  padding:30px 28px;width:340px;box-shadow:0 8px 30px rgba(20,30,45,.06)}
.login-brand{font-size:20px;font-weight:800;text-align:center}
.login-sub{text-align:center;color:var(--mut);font-size:13px;margin:4px 0 20px}
.login-card label{display:block;font-size:13px;font-weight:600;color:var(--mut);margin-bottom:12px}
.login-card input{width:100%;margin-top:5px;padding:10px 12px;border:1px solid var(--line);
  border-radius:9px;font:inherit;background:#fbfcfe}
.login-card input:focus{outline:none;border-color:var(--accent)}
.login-card button{width:100%;margin-top:6px;padding:11px;border:none;border-radius:9px;
  background:var(--accent);color:var(--accent-ink);font-weight:700;font-size:15px;cursor:pointer}
.error{background:#fdecea;color:var(--danger);border:1px solid #f5c6c2;
  border-radius:8px;padding:9px 12px;font-size:13px;margin-bottom:14px}

/* flash */
.flash{border-radius:8px;padding:9px 13px;font-size:14px;margin-bottom:14px;border:1px solid}
.flash-ok{background:#e9f4ef;color:var(--accent);border-color:#bfe0d3}
.flash-error{background:#fdecea;color:var(--danger);border-color:#f5c6c2}

/* tables */
table.grid{width:100%;border-collapse:collapse;background:var(--panel);
  border:1px solid var(--line);border-radius:10px;overflow:hidden;font-size:14px}
table.grid th{background:#f7f9fb;text-align:left;padding:9px 12px;color:var(--mut);
  font-size:12px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}
table.grid td{padding:9px 12px;border-bottom:1px solid var(--line)}
table.grid tr:last-child td{border-bottom:none}
table.grid .muted{color:var(--mut)}
.actions{display:flex;gap:6px;align-items:center}
.actions form{display:inline}

/* pills */
.pill{font-size:11px;font-weight:700;text-transform:uppercase;border-radius:999px;padding:2px 9px}
.pill-open,.pill-submitted{background:#eef4fb;color:#2b6cb0}
.pill-approved,.pill-paid{background:#e6f0ec;color:var(--accent)}
.pill-rejected,.pill-closed{background:#fdecea;color:var(--danger)}

/* forms */
.inline-form{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin:6px 0 22px}
.entry-form{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-bottom:10px}
.inline-form label,.entry-form label{display:flex;flex-direction:column;font-size:12px;
  font-weight:600;color:var(--mut);gap:4px}
.entry-form label.grow{flex:1;min-width:160px}
.inline-form input,.inline-form select,.entry-form input,.entry-form select{
  padding:8px 10px;border:1px solid var(--line);border-radius:8px;font:inherit;background:#fbfcfe}
.inline-form button,.entry-form button{padding:9px 16px;border:none;border-radius:8px;
  background:var(--accent);color:#fff;font-weight:700;cursor:pointer}
.note-inline{font-size:12.5px;color:var(--mut);align-self:center}

/* small buttons */
.btn-sm{font-size:12px;font-weight:700;border:1px solid var(--line);background:var(--panel);
  color:var(--ink);border-radius:7px;padding:4px 10px;cursor:pointer;text-decoration:none}
.btn-ok{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-danger{background:#fff;color:var(--danger);border-color:#f0c4c0}
tr.editing td{background:#fbfdff}

/* paycheck breakdown */
.paycheck{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:16px 18px;margin-bottom:16px}
.pc-head{display:flex;align-items:center;gap:12px;margin-bottom:12px;
  border-bottom:1px solid var(--line);padding-bottom:10px}
.pc-cols{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:720px){.pc-cols{grid-template-columns:1fr}}
.pc-sub{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  color:var(--mut);margin:12px 0 4px}
.pc-line{display:flex;justify-content:space-between;font-size:14px;padding:3px 0}
.pc-line span:last-child{font-variant-numeric:tabular-nums}
.pc-gross{font-weight:700;font-size:16px}
.pc-net{font-weight:700;color:var(--accent);border-top:1px solid var(--line);
  margin-top:6px;padding-top:8px}
.finalize-btn{padding:11px 22px;border:none;border-radius:9px;background:var(--accent);
  color:#fff;font-weight:700;font-size:15px;cursor:pointer}

/* filings */
.reminders{margin:6px 0 18px;display:flex;flex-direction:column;gap:8px}
.rem{border-radius:8px;padding:9px 13px;font-size:13.5px;border:1px solid}
.rem-overdue{background:#fdecea;color:var(--danger);border-color:#f5c6c2}
.rem-soon{background:#fff7e6;color:#8a5a00;border-color:#f0dca8}
.overdue-cell{color:var(--danger);font-weight:700}
.file-form{display:flex;gap:6px;align-items:center;flex-wrap:nowrap}
.file-form input{padding:5px 8px;border:1px solid var(--line);border-radius:7px;font:inherit;font-size:12px}
