:root{
  --ink:#10201c; --ink-soft:#48564f; --line:#dfe5e0;
  --bg:#f4f1ea; --paper:#fffdf8; --teal:#0c6b5e; --teal-dk:#084a40;
  --gold:#b8893a; --danger:#b3261e; --ok:#0c6b5e;
  --radius:12px; --shadow:0 1px 2px rgba(16,32,28,.06),0 8px 24px rgba(16,32,28,.06);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Outfit",system-ui,sans-serif;font-size:15px;line-height:1.5}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-family:"Fraunces",Georgia,serif;font-weight:600;letter-spacing:-.01em;margin:0}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;background:var(--teal-dk);color:#eef3f1}
.brand{font-family:"Fraunces",serif;font-size:20px;font-weight:600;letter-spacing:.01em}
.brand em{color:#cde7df;font-style:normal}
.brand .mark{display:inline-grid;place-items:center;width:26px;height:26px;margin-right:6px;
  background:var(--gold);color:#1c1305;border-radius:7px;font-weight:700;transform:translateY(2px)}
.nav{display:flex;align-items:center;gap:18px;font-size:14px}
.nav a{color:#dcebe6}
.nav .who{color:#9fc1b8;font-size:13px}

.wrap{max-width:1100px;margin:0 auto;padding:32px 28px 60px}
.foot{text-align:center;color:var(--ink-soft);font-size:12.5px;padding:24px}

/* page head */
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px}
.count{display:inline-block;margin-left:8px;padding:1px 10px;background:#e7efec;
  color:var(--teal-dk);border-radius:999px;font-size:13px;font-family:"Outfit";vertical-align:middle}

/* buttons */
.btn{display:inline-block;background:var(--teal);color:#fff;border:0;cursor:pointer;
  padding:10px 18px;border-radius:10px;font:inherit;font-weight:500}
.btn:hover{background:var(--teal-dk);text-decoration:none}
.btn-ghost{display:inline-block;border:1px solid var(--line);background:var(--paper);
  color:var(--ink);padding:9px 16px;border-radius:10px;cursor:pointer;font:inherit}
.btn-ghost:hover{border-color:var(--teal);text-decoration:none}
.link-danger{background:none;border:0;color:var(--danger);cursor:pointer;font:inherit;padding:0}
.link-danger:hover{text-decoration:underline}
.inline{display:inline}

/* search + filters */
.ai-search{display:flex;gap:10px;margin-bottom:8px}
.ai-search input{flex:1;padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  background:var(--paper);font:inherit}
.ai-search input:focus{outline:2px solid var(--teal);border-color:var(--teal)}
.ai-note{color:var(--ink-soft);font-size:13px;margin:0 0 18px}
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.filters input,.filters select{padding:9px 12px;border:1px solid var(--line);border-radius:9px;
  background:var(--paper);font:inherit}

/* table */
.table-wrap{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
thead th{text-align:left;padding:13px 14px;color:var(--ink-soft);font-weight:600;
  border-bottom:1px solid var(--line);white-space:nowrap;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em}
tbody td{padding:13px 14px;border-bottom:1px solid #eef1ed;vertical-align:middle}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:#faf8f2}
.mono{font-family:ui-monospace,Menlo,monospace;font-size:13px}
.num{text-align:right;font-variant-numeric:tabular-nums}
.empty{text-align:center;color:var(--ink-soft);padding:34px}
.actions{white-space:nowrap;display:flex;gap:12px;align-items:center}
.tag{background:#eef3f1;color:var(--teal-dk);padding:2px 9px;border-radius:6px;font-size:12px}
.status{padding:2px 9px;border-radius:6px;font-size:12px;text-transform:capitalize}
.status-active{background:#e3f0ea;color:#0c6b5e}
.status-inactive{background:#efeee8;color:#6b6b5e}
.status-resigned{background:#f3e9da;color:#8a5a18}
.status-terminated{background:#f6e2e0;color:#b3261e}

/* auth */
.auth-card{max-width:380px;margin:6vh auto;background:var(--paper);border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow);padding:34px}
.auth-title{font-size:26px;margin-bottom:2px}
.auth-sub{color:var(--ink-soft);margin:0 0 22px}
.auth-card label{display:block;margin-bottom:14px;font-size:14px;color:var(--ink-soft)}
.auth-card input{display:block;width:100%;margin-top:6px;padding:11px 12px;border:1px solid var(--line);
  border-radius:9px;font:inherit;background:#fff}
.auth-card .btn{width:100%;margin-top:6px}

/* form grid */
.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:26px}
.form-grid label{display:flex;flex-direction:column;font-size:13px;color:var(--ink-soft);gap:6px}
.form-grid input,.form-grid select{padding:10px 12px;border:1px solid var(--line);border-radius:9px;
  font:inherit;background:#fff;color:var(--ink)}
.form-grid input:focus,.form-grid select:focus{outline:2px solid var(--teal);border-color:var(--teal)}
.form-grid .has-error input{border-color:var(--danger)}
.form-grid .err{color:var(--danger);font-size:12px}
.section-sep{grid-column:1/-1;border-top:1px solid var(--line);padding-top:14px;margin-top:6px;
  font-weight:600;color:var(--ink);font-size:13.5px}
.form-actions{grid-column:1/-1;display:flex;gap:12px;margin-top:8px}

/* flash */
.flash{padding:12px 16px;border-radius:10px;margin-bottom:16px;font-size:14px}
.flash.success{background:#e3f0ea;color:#0c5a4e;border:1px solid #bfe0d4}
.flash.error{background:#f9e6e4;color:#8c1f18;border:1px solid #eec4c0}
.flash.warn{background:#fbf1de;color:#7a531a;border:1px solid #ecd6a8}
.flash.info{background:#eaf0ef;color:#3a4a45;border:1px solid #d4e0db}
.flash ul{margin:8px 0 0;padding-left:20px}

@media(max-width:780px){.form-grid{grid-template-columns:1fr}.wrap{padding:20px 16px 50px}}

/* department form */
.dept-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 20px;margin-bottom:20px}
.dept-fields{display:flex;flex-wrap:wrap;gap:16px}
.dept-form .field{display:flex;flex-direction:column;gap:6px;
  font-size:13px;color:var(--ink-soft);flex:1 1 220px;min-width:200px}
.dept-form .field span{font-weight:500}
.dept-form .field input{width:100%;padding:10px 12px;border:1px solid var(--line);
  border-radius:9px;font:inherit;background:#fff;color:var(--ink)}
.dept-form .field input:focus{outline:2px solid var(--teal);border-color:var(--teal)}
.dept-actions{display:flex;gap:10px;margin-top:14px}

/* attendance */
.att-tools{display:flex;gap:10px}
.date-nav{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.date-nav input[type=date]{padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:var(--paper);font:inherit}
.daytype{padding:3px 11px;border-radius:999px;font-size:12.5px;font-weight:500}
.daytype-workday{background:#e7efec;color:var(--teal-dk)}
.daytype-weekend{background:#efeadf;color:#7a6a42}
.daytype-holiday{background:#f3e2df;color:#9a3b2e}
.stat-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}
.stat{flex:1 1 120px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:14px 16px;font-size:12.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.03em}
.stat-n{display:block;font-family:"Fraunces",serif;font-size:26px;color:var(--ink);letter-spacing:-.01em;text-transform:none}
.link-soft{background:none;border:0;color:var(--teal);cursor:pointer;font:inherit;padding:0}
.link-soft:hover{text-decoration:underline}
.status-present{background:#e3f0ea;color:#0c6b5e}
.status-absent{background:#f6e2e0;color:#b3261e}
.status-half_day{background:#f3e9da;color:#8a5a18}
.status-half-day{background:#f3e9da;color:#8a5a18}
.status-leave{background:#e7eef6;color:#2c5a8a}
.status-holiday{background:#f3e2df;color:#9a3b2e}
.status-off{background:#efeee8;color:#6b6b5e}
.row-weekend td{background:#faf7f0}
.row-holiday td{background:#fbf0ee}
.span2{grid-column:span 2}
.span3{grid-column:1/-1}
.att-readout{font-size:14px;color:var(--ink-soft)}
.att-readout strong{color:var(--ink)}
.card-note{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 20px;margin-bottom:18px;font-size:14px;color:var(--ink-soft)}
.card-note pre{background:#f3f1ea;border:1px solid var(--line);border-radius:8px;padding:12px;
  overflow:auto;font-size:13px;color:var(--ink)}

/* shift setup */
.shift-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 20px;margin-bottom:20px}
.shift-fields{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}
.shift-form .field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-soft);flex:1 1 160px}
.shift-form .field.sm{flex:0 0 110px}
.shift-form .field span{font-weight:500}
.shift-form .field input,.shift-form .field select{padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;color:var(--ink)}
.shift-form .field input[type=color]{padding:3px;height:40px}
.check{display:flex;align-items:center;gap:7px;font-size:13.5px;color:var(--ink);flex:0 0 auto}
.shift-chip{display:inline-block;min-width:42px;text-align:center;color:#fff;font-size:11.5px;font-weight:600;
  padding:3px 9px;border-radius:6px;letter-spacing:.03em}

/* assign */
.assign-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:8px}
.assign-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:20px}
.assign-card h2{font-family:"Fraunces",serif;font-size:18px;font-weight:600;margin:0 0 12px}
.assign-card .field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-soft);margin-bottom:12px}
.assign-card .field span{font-weight:500}
.assign-card input,.assign-card select{padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;color:var(--ink)}
.assign-card .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.empbox{max-height:200px;overflow:auto;border:1px solid var(--line);border-radius:9px;padding:8px 10px;margin-bottom:12px;background:#fff}
.empbox .emp{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13.5px;color:var(--ink)}
.mt{font-family:"Fraunces",serif;font-weight:600;margin:26px 0 12px}

/* timetable */
table.timetable{font-size:13px}
table.timetable th,table.timetable td{text-align:center;padding:8px 6px}
.timetable .tt-emp{text-align:left;white-space:nowrap;position:sticky;left:0;background:var(--paper);z-index:1}
.timetable thead .tt-emp{z-index:2}
.tt-day{min-width:46px}
.tt-dow{display:block;font-size:11px;color:var(--ink-soft);text-transform:uppercase}
.tt-date{display:block;font-size:13px;color:var(--ink)}
.tt-weekend{background:#faf7f0}
.tt-cell{padding:6px 4px}
.tt-empty{color:#cbd3ce}
.legend{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:16px;font-size:13px;color:var(--ink-soft)}
.legend-item{display:flex;align-items:center;gap:7px}

@media(max-width:780px){.assign-cols{grid-template-columns:1fr}}
