/* ── TOKENS ── */
:root[data-theme="dark"] {
  --bg: #0f0f0f; --bg2: #141414; --bg3: #1a1a1a; --bg4: #222; --bg5: #2a2a2a;
  --border: #252525; --border2: #333;
  --text: #ebebeb; --text2: #aaa; --text3: #666; --text4: #3f3f3f;
  --accent: #2563eb; --accent-l: #60a5fa; --accent-bg: #0c1a3a;
  --green: #34d399; --green-bg: #052e16;
  --amber: #fbbf24; --amber-bg: #292100;
  --red: #f87171; --red-bg: #200a0a;
  --purple: #c084fc; --purple-bg: #1e0938;
  --shadow: 0 12px 40px rgba(0,0,0,.55);
  --modal-bg: #0f0f0f;
}
:root[data-theme="light"] {
  --bg: #f4f4f5; --bg2: #fff; --bg3: #fafafa; --bg4: #f0f0f0; --bg5: #e8e8e8;
  --border: #e4e4e7; --border2: #d4d4d8;
  --text: #111; --text2: #555; --text3: #888; --text4: #d4d4d8;
  --accent: #2563eb; --accent-l: #1d4ed8; --accent-bg: #eff6ff;
  --green: #16a34a; --green-bg: #f0fdf4;
  --amber: #d97706; --amber-bg: #fffbeb;
  --red: #dc2626; --red-bg: #fef2f2;
  --purple: #9333ea; --purple-bg: #faf5ff;
  --shadow: 0 12px 40px rgba(0,0,0,.1);
  --modal-bg: #fff;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg); color: var(--text);
  min-height: 100vh; transition: background .2s, color .2s;
}

/* ── HEADER ── */
.hdr {
  background: var(--bg2); border-bottom: 1px solid var(--border);
  padding: 11px 24px; display: flex; align-items: center;
  position: sticky; top: 0; z-index: 20;
}
.hdr-brand { font-size: 14px; font-weight: 800; color: var(--text); letter-spacing: -.01em; }
.hdr-center {
  position: absolute; left: 50%; transform: translateX(-50%);
  font-size: 17px; font-weight: 700; color: var(--text);
  letter-spacing: -.02em; white-space: nowrap;
}
.hdr-right { margin-left: auto; display: flex; align-items: center; gap: 7px; }
.tt-lbl { font-size: 11px; color: var(--text3); }
.tt-track {
  width: 38px; height: 21px; background: var(--bg4);
  border: 1px solid var(--border2); border-radius: 11px;
  cursor: pointer; position: relative; transition: background .2s;
}
.tt-track.on { background: var(--accent); border-color: var(--accent); }
.tt-knob {
  width: 15px; height: 15px; background: var(--text3);
  border-radius: 50%; position: absolute; top: 2px; left: 2px;
  transition: left .2s, background .2s;
}
.tt-knob.on { left: 19px; background: #fff; }

/* ── LAYOUT ── */
.layout { display: flex; height: calc(100vh - 48px); }

/* ── SIDEBAR ── */
.sidebar { width: 210px; background: var(--bg2); border-right: 1px solid var(--border); padding: 14px 0; flex-shrink: 0; }
.sb-sec { font-size: 9px; font-weight: 700; color: var(--text4); letter-spacing: .12em; text-transform: uppercase; padding: 12px 18px 5px; }
.nav-item {
  display: flex; align-items: center; gap: 9px;
  padding: 9px 18px; font-size: 13px; color: var(--text2);
  cursor: pointer; border-left: 2px solid transparent; transition: all .12s;
}
.nav-item:hover { color: var(--text); background: var(--bg3); }
.nav-item.active { color: var(--text); background: var(--bg3); border-left-color: var(--accent); }
.nav-icon { font-size: 13px; width: 17px; text-align: center; flex-shrink: 0; }
.nbadge {
  margin-left: auto; background: var(--accent-bg); color: var(--accent-l);
  font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 20px;
}

/* ── MAIN / TAB PANES ── */
.main { flex: 1; overflow-y: auto; }
.tab-pane { display: none; }
.tab-pane.active { display: block; }
.content { padding: 22px 26px; }
.pg-title { font-size: 19px; font-weight: 700; margin-bottom: 3px; }
.pg-sub { font-size: 13px; color: var(--text3); margin-bottom: 22px; }

/* ── STAT CARDS ── */
.stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 13px; margin-bottom: 22px; }
.sc { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 15px 17px; }
.sc-lbl { font-size: 11px; color: var(--text3); font-weight: 500; margin-bottom: 5px; }
.sc-val { font-size: 23px; font-weight: 700; }
.sc-sub { font-size: 11px; color: var(--text3); margin-top: 3px; }
.up-item { font-size: 10px; color: var(--text3); display: flex; gap: 5px; margin-top: 3px; align-items: center; }
.up-dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }

/* ── TABLE ── */
.tbl-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 11px; }
.tbl-title { font-size: 14px; font-weight: 600; }
.btn { background: var(--accent); color: #fff; font-size: 12px; font-weight: 600; padding: 7px 15px; border-radius: 7px; border: none; cursor: pointer; }
.btn:hover { opacity: .9; }
.btn-ghost { background: transparent; color: var(--text2); border: 1px solid var(--border2); font-size: 12px; font-weight: 500; padding: 6px 13px; border-radius: 7px; cursor: pointer; }
.emp-search {
  background: var(--bg3); border: 1px solid var(--border2); border-radius: 7px;
  padding: 6px 12px; font-size: 12px; color: var(--text); outline: none;
  width: 180px; font-family: inherit;
}
.emp-search:focus { border-color: var(--accent); width: 220px; }
.emp-search::placeholder { color: var(--text4); }
.tbl-wrap { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
table { width: 100%; border-collapse: collapse; }
thead th { text-align: left; font-size: 10px; font-weight: 700; color: var(--text3); letter-spacing: .07em; text-transform: uppercase; padding: 9px 15px; border-bottom: 1px solid var(--border); background: var(--bg3); }
tbody tr { border-bottom: 1px solid var(--border); transition: background .1s; }
tbody tr:last-child { border-bottom: none; }
tbody tr:hover { background: var(--bg3); }
tbody td { padding: 11px 15px; font-size: 13px; color: var(--text2); vertical-align: middle; }
.av { width: 29px; height: 29px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; margin-right: 8px; vertical-align: middle; flex-shrink: 0; }
.emp-link { font-weight: 600; color: var(--accent-l); cursor: pointer; background: none; border: none; font-size: 13px; font-family: inherit; padding: 0; }
.emp-link:hover { text-decoration: underline; }
.emp-role { font-size: 11px; color: var(--text3); display: block; padding-left: 37px; margin-top: 1px; }
.bar { width: 78px; height: 5px; background: var(--bg5); border-radius: 3px; display: inline-block; vertical-align: middle; margin-right: 6px; }
.bar-fill { height: 100%; border-radius: 3px; }
.tag { display: inline-block; font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 20px; }
.tag-green { background: var(--green-bg); color: var(--green); }
.tag-amber { background: var(--amber-bg); color: var(--amber); }

/* ── QUICK ACTION BUTTONS ── */
.qa { display: flex; align-items: center; justify-content: center; gap: 7px; }
.qb { width: 27px; height: 27px; border-radius: 50%; border: none; font-size: 15px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; line-height: 1; transition: transform .1s, box-shadow .1s; }
.qb:active { transform: scale(.9); }
.qb-plus { background: var(--accent); color: #fff; }
.qb-plus:hover { box-shadow: 0 0 0 3px rgba(37,99,235,.25); }
.qb-edit { background: var(--bg3); color: var(--text2); border: 1px solid var(--border2); font-size: 13px; }
.qb-edit:hover { border-color: var(--accent); color: var(--accent-l); box-shadow: 0 0 0 3px rgba(37,99,235,.15); }

/* ── CALENDAR (shared) ── */
.cal-wrap { background: var(--bg2); border: 1px solid var(--border); border-radius: 11px; padding: 18px; }
.cal-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.cal-month { font-size: 14px; font-weight: 700; }
.cal-nav-btn { background: none; border: 1px solid var(--border2); color: var(--text2); font-size: 12px; padding: 5px 12px; border-radius: 5px; cursor: pointer; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-dh { text-align: center; font-size: 9px; font-weight: 700; color: var(--text4); padding: 5px; }
.cal-d { text-align: center; padding: 9px 4px; font-size: 12px; color: var(--text2); border-radius: 6px; cursor: default; min-height: 38px; }
.cal-d.today { background: var(--accent-bg); color: var(--accent-l); font-weight: 700; }
.cal-d.empty { color: var(--text4); }
.cal-d.has-leave { cursor: pointer; }
.cal-d:hover:not(.empty) { background: var(--bg3); }
.leave-pip { display: inline-block; width: 5px; height: 5px; border-radius: 50%; margin: 1px; }
.cal-legend { display: flex; gap: 14px; margin-top: 12px; flex-wrap: wrap; }
.leg { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text3); }
.leg-dot { width: 8px; height: 8px; border-radius: 50%; }

/* ── CALENDAR LAYOUT (team view) ── */
.cal-layout { display: grid; grid-template-columns: 1fr 300px; gap: 20px; }
.feed { background: var(--bg2); border: 1px solid var(--border); border-radius: 11px; overflow: hidden; }
.feed-hdr { padding: 14px 16px; border-bottom: 1px solid var(--border); font-size: 13px; font-weight: 600; }
.feed-item { padding: 12px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; gap: 10px; }
.feed-item:last-child { border-bottom: none; }
.feed-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.feed-info { flex: 1; }
.feed-name { font-size: 13px; font-weight: 500; color: var(--text); margin-bottom: 2px; }
.feed-detail { font-size: 12px; color: var(--text3); }
.feed-date { font-size: 11px; color: var(--text4); white-space: nowrap; }

/* ── EMPLOYEE DETAIL ── */
/* ── EMPLOYEE DETAIL PICKER — search + department sections ── */
.picker-header-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 22px; }
.dept-section { margin-bottom: 24px; }
.dept-header {
  font-size: 11px; font-weight: 700; color: var(--text3);
  letter-spacing: .1em; text-transform: uppercase;
  padding: 8px 0 10px; border-bottom: 1px solid var(--border); margin-bottom: 12px;
  display: flex; align-items: center; gap: 8px;
}
.dept-count {
  background: var(--bg4); color: var(--text3); font-size: 10px;
  font-weight: 700; padding: 1px 7px; border-radius: 20px;
  letter-spacing: 0;
}

/* ── EMPLOYEE DETAIL EMPTY-STATE PICKER ── */
.picker-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.picker-card {
  display: flex; align-items: center; gap: 12px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 10px; padding: 12px 14px;
  cursor: pointer; font-family: inherit; text-align: left;
  transition: border-color 0.12s, background 0.12s;
}
.picker-card:hover { border-color: var(--accent); background: var(--bg3); }
.picker-av {
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; flex-shrink: 0;
}
.picker-info { flex: 1; min-width: 0; }
.picker-name { font-size: 13px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.picker-role { font-size: 11px; color: var(--text3); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.picker-balance { text-align: right; flex-shrink: 0; }
.picker-rem { font-size: 16px; font-weight: 700; color: var(--accent-l); }
.picker-rem-lbl { font-size: 9px; color: var(--text3); text-transform: uppercase; letter-spacing: .05em; }

.detail-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 60px 20px; text-align: center; }
.detail-empty-icon { font-size: 40px; margin-bottom: 14px; opacity: .4; }
.detail-empty-text { font-size: 14px; color: var(--text2); margin-bottom: 6px; }
.detail-empty-sub { font-size: 13px; color: var(--text3); }
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text3); padding: 14px 26px 0; }
.bc-link { color: var(--accent-l); cursor: pointer; background: none; border: none; font-family: inherit; font-size: 12px; padding: 0; }
.bc-link:hover { text-decoration: underline; }
.bc-sep { color: var(--text4); }
.detail-subtabs { display: flex; border-bottom: 1px solid var(--border); padding: 0 26px; }
.dst { padding: 9px 16px; font-size: 12px; font-weight: 500; color: var(--text3); cursor: pointer; border-bottom: 2px solid transparent; }
.dst:hover { color: var(--text2); }
.dst.active { color: var(--text); border-bottom-color: var(--accent); }
.detail-layout { display: grid; grid-template-columns: 320px 1fr; gap: 20px; padding: 22px 26px; }
.panel { background: var(--bg2); border: 1px solid var(--border); border-radius: 11px; }
.panel-hdr { padding: 15px 18px; border-bottom: 1px solid var(--border); }
.panel-body { padding: 15px 18px; }
.emp-card { display: flex; align-items: center; gap: 13px; }
.emp-av-lg { width: 46px; height: 46px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 15px; font-weight: 700; }
.emp-nm { font-size: 16px; font-weight: 700; }
.emp-rl { font-size: 12px; color: var(--text3); margin-top: 2px; }
.emp-jn { font-size: 11px; color: var(--text4); margin-top: 2px; }
.alloc-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 14px 0; }
.a3c { background: var(--bg3); border-radius: 8px; padding: 11px; text-align: center; }
.a3v { font-size: 20px; font-weight: 700; }
.a3l { font-size: 10px; color: var(--text3); margin-top: 2px; }
.sec-lbl { font-size: 10px; font-weight: 700; color: var(--text3); letter-spacing: .07em; text-transform: uppercase; margin: 14px 0 6px; }
.ltype-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--border); }
.ltype-row:last-child { border-bottom: none; }
.ltype-nm { font-size: 13px; color: var(--text2); }
.ltype-ct { font-size: 14px; font-weight: 700; color: var(--text); }
.hi { display: flex; align-items: flex-start; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--border); }
.hi:last-child { border-bottom: none; }
.hi-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.hi-date { font-size: 12px; font-weight: 600; color: var(--text2); margin-bottom: 2px; }
.hi-rsn { font-size: 12px; color: var(--text3); }
.hi-d { font-size: 10px; color: var(--text4); white-space: nowrap; }
.leave-type-tag { font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 20px; margin-left: 6px; }
.manual-adj { background: var(--accent-bg); border-radius: 7px; padding: 8px 12px; display: flex; align-items: center; gap: 9px; margin-top: 12px; }
.adj-t { font-size: 12px; color: var(--accent-l); flex: 1; }
.adj-n { font-size: 11px; color: var(--text4); }
.add-lb-btn { display: block; width: 100%; margin-top: 12px; background: var(--bg3); border: 1px solid var(--border2); color: var(--text2); font-size: 13px; font-weight: 500; padding: 9px; border-radius: 8px; cursor: pointer; text-align: center; }
.add-lb-btn:hover { border-color: var(--accent); color: var(--accent-l); }
.upcoming-panel { background: var(--bg3); border: 1px solid var(--border); border-radius: 9px; padding: 14px; margin-top: 16px; }
.up-title { font-size: 12px; font-weight: 600; color: var(--text2); margin-bottom: 10px; }
.ul-i { display: flex; align-items: center; gap: 9px; padding: 7px 0; border-bottom: 1px solid var(--border); }
.ul-i:last-child { border-bottom: none; }
.ul-date { font-size: 12px; font-weight: 600; color: var(--text); min-width: 65px; }
.ul-type { font-size: 11px; font-weight: 600; }
.ul-rsn { font-size: 12px; color: var(--text3); flex: 1; }

/* ── POLICY TAB ── */
.policy-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.policy-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 11px; overflow: hidden; }
.pc-hdr { padding: 14px 18px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
.pc-icon { font-size: 18px; }
.pc-title { font-size: 13px; font-weight: 700; }
.pc-sub { font-size: 11px; color: var(--text3); margin-top: 1px; }
.pc-body { padding: 6px 18px 14px; }
.pr { display: flex; align-items: center; justify-content: space-between; padding: 11px 0; border-bottom: 1px solid var(--border); }
.pr:last-child { border-bottom: none; }
.pr-key { font-size: 13px; color: var(--text2); }
.pr-val { font-size: 14px; font-weight: 700; color: var(--text); text-align: right; }
.pr-note { font-size: 11px; color: var(--text3); margin-top: 2px; }
.rule-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 11px; overflow: hidden; grid-column: 1 / -1; }
.rule-list { padding: 6px 18px 14px; }
.rule-item { display: flex; align-items: flex-start; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.rule-item:last-child { border-bottom: none; }
.rule-num { width: 22px; height: 22px; border-radius: 50%; background: var(--accent-bg); color: var(--accent-l); font-size: 11px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.rule-text { font-size: 13px; color: var(--text2); line-height: 1.5; }
.rule-text strong { color: var(--text); font-weight: 600; }

/* ── MODAL ── */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,.65); display: flex; align-items: center; justify-content: center; z-index: 50; backdrop-filter: blur(3px); }
.overlay.hidden { display: none; }
.modal { background: var(--modal-bg); border: 1px solid var(--border2); border-radius: 14px; width: 450px; max-width: 95vw; box-shadow: var(--shadow); }
.m-hdr { padding: 17px 20px 13px; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; justify-content: space-between; }
.m-title { font-size: 15px; font-weight: 700; }
.m-emp { font-size: 12px; color: var(--accent-l); margin-top: 2px; }
.m-badge { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 20px; margin-top: 5px; display: inline-block; }
.m-badge-add { background: var(--accent-bg); color: var(--accent-l); }
.m-badge-rem { background: var(--red-bg); color: var(--red); }
.m-close { width: 27px; height: 27px; border-radius: 50%; background: var(--bg4); border: none; color: var(--text2); font-size: 15px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.m-body { padding: 18px 20px; }
.m-lbl { font-size: 10px; font-weight: 700; color: var(--text3); letter-spacing: .07em; text-transform: uppercase; margin-bottom: 8px; }
.ltype-pills { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 18px; }
.lpill { padding: 6px 13px; border-radius: 20px; font-size: 12px; font-weight: 600; border: 1.5px solid var(--border2); color: var(--text2); cursor: pointer; background: var(--bg3); transition: all .15s; white-space: nowrap; }
.lpill:hover { border-color: var(--accent); color: var(--accent-l); }
.lpill.sel-casual          { background: var(--accent-bg); border-color: var(--accent);   color: var(--accent-l); }
.lpill.sel-sick            { background: var(--red-bg);    border-color: var(--red);      color: var(--red);      }
.lpill.sel-mental-health   { background: var(--amber-bg);  border-color: var(--amber);    color: var(--amber);    }
.lpill.sel-wellness        { background: var(--green-bg);  border-color: var(--green);    color: var(--green);    }
.lpill.sel-birthday        { background: var(--purple-bg); border-color: var(--purple);   color: var(--purple);   }
.lpill.sel-anniversary     { background: var(--purple-bg); border-color: var(--purple);   color: var(--purple);   }
.lpill.sel-comp-off        { background: var(--green-bg);  border-color: var(--green);    color: var(--green);    }
.lpill.sel-maternity       { background: var(--purple-bg); border-color: var(--purple);   color: var(--purple);   }
.lpill.sel-paternity       { background: var(--purple-bg); border-color: var(--purple);   color: var(--purple);   }
.lpill.sel-loss-of-pay     { background: var(--red-bg);    border-color: var(--red);      color: var(--red);      }
.mini-cal { background: var(--bg3); border: 1px solid var(--border); border-radius: 9px; padding: 13px; margin-bottom: 13px; }
.mini-cal-hdr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.mini-cal-month { font-size: 13px; font-weight: 700; }
.mini-cal-nav { background: none; border: 1px solid var(--border2); color: var(--text2); font-size: 11px; padding: 3px 8px; border-radius: 5px; cursor: pointer; }
.mini-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.mcd-h { text-align: center; font-size: 9px; font-weight: 700; color: var(--text4); padding: 3px; }
.mcd { text-align: center; padding: 6px 2px; font-size: 12px; color: var(--text2); border-radius: 5px; cursor: pointer; border: 1.5px solid transparent; transition: all .1s; user-select: none; }
.mcd:hover:not(.mcd-empty) { background: var(--bg4); color: var(--text); }
.mcd.mcd-today { font-weight: 700; color: var(--accent-l); }
.mcd.mcd-sel { background: var(--accent); color: #fff; border-color: var(--accent); font-weight: 600; }
.mcd.mcd-prior { color: var(--text3); } /* past dates — dimmed but still clickable */
.mcd.mcd-empty { cursor: default; }
.mcd.mcd-exist { background: var(--red-bg); color: var(--red); font-weight: 600; }
.mcd.mcd-exist.mcd-sel { background: var(--bg4); color: var(--text3); text-decoration: line-through; }
.chips { display: flex; flex-wrap: wrap; gap: 5px; min-height: 24px; margin-bottom: 13px; }
.chip { background: var(--accent-bg); color: var(--accent-l); font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 20px; display: flex; align-items: center; gap: 4px; }
.chip-rem { background: var(--red-bg); color: var(--red); }
.chip-x { cursor: pointer; opacity: .7; font-size: 12px; }
.chip-x:hover { opacity: 1; }
.no-dates { font-size: 12px; color: var(--text4); }
.reason-inp { width: 100%; background: var(--bg3); border: 1px solid var(--border2); border-radius: 7px; padding: 8px 11px; font-size: 13px; color: var(--text); outline: none; resize: none; font-family: inherit; }
.reason-inp:focus { border-color: var(--accent); }
.reason-inp::placeholder { color: var(--text4); }
.m-footer { padding: 13px 20px; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.m-summary { font-size: 13px; color: var(--text2); }
.m-summary strong { color: var(--text); }
.btn-save { background: var(--accent); color: #fff; font-size: 13px; font-weight: 700; padding: 8px 20px; border-radius: 8px; border: none; cursor: pointer; }
.btn-save:hover { opacity: .9; }
.btn-save-red { background: var(--red) !important; }
.btn-cancel { background: none; border: 1px solid var(--border2); color: var(--text2); font-size: 13px; font-weight: 500; padding: 8px 15px; border-radius: 8px; cursor: pointer; }

/* ── ADD EMPLOYEE MODAL ── */
.add-emp-form { display: flex; flex-direction: column; gap: 14px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-field { display: flex; flex-direction: column; gap: 5px; }
.form-field label { font-size: 11px; font-weight: 700; color: var(--text3); letter-spacing: .07em; text-transform: uppercase; }
.form-field input, .form-field select {
  background: var(--bg3); border: 1px solid var(--border2);
  border-radius: 7px; padding: 8px 11px; font-size: 13px;
  color: var(--text); outline: none; font-family: inherit;
}
.form-field input:focus, .form-field select:focus { border-color: var(--accent); }
.form-field select option { background: var(--bg3); }

/* ── UTILITY ── */
.note-ann { background: var(--accent-bg); border: 1px dashed var(--accent); border-radius: 8px; padding: 9px 13px; font-size: 12px; color: var(--accent-l); margin-top: 14px; }
.empty-feed { padding: 20px 16px; font-size: 13px; color: var(--text3); text-align: center; }

/* ── ROW ⋯ MENU (Edit / Delete) ── */
.qb-menu { background: transparent; color: var(--text3); border: 1px solid var(--border2); }
.qb-menu:hover { color: var(--text); border-color: var(--accent); }
.row-menu {
  position: absolute; right: 6px; top: 36px;
  background: var(--bg2); border: 1px solid var(--border2);
  border-radius: 8px; box-shadow: var(--shadow);
  z-index: 30; min-width: 170px; padding: 4px;
  text-align: left;
}
.row-menu-item {
  display: block; width: 100%; text-align: left;
  background: none; border: none; padding: 8px 12px;
  font-size: 12px; color: var(--text2); cursor: pointer;
  border-radius: 5px; font-family: inherit;
}
.row-menu-item:hover { background: var(--bg3); color: var(--text); }
.row-menu-item-danger { color: var(--red); }
.row-menu-item-danger:hover { background: var(--red-bg); color: var(--red); }

/* ── BULK UPLOAD ── */
.modal.modal-wide { width: 720px; }
.bulk-instructions { padding: 12px 14px; background: var(--bg3); border-radius: 8px; border: 1px solid var(--border); margin-bottom: 12px; }
.bulk-example { background: var(--bg); border: 1px solid var(--border); border-radius: 6px; padding: 8px 10px; margin-top: 6px; }
.bulk-example-label { font-size: 10px; color: var(--text3); margin-bottom: 4px; font-weight: 600; }
.bulk-example-code { font-family: 'SF Mono', Monaco, monospace; font-size: 11px; color: var(--text2); white-space: pre; overflow-x: auto; line-height: 1.5; }
.bulk-textarea {
  width: 100%; background: var(--bg3); border: 1px solid var(--border2);
  border-radius: 7px; padding: 10px 12px; font-size: 12px;
  color: var(--text); outline: none; resize: vertical;
  font-family: 'SF Mono', Monaco, monospace; min-height: 120px;
}
.bulk-textarea:focus { border-color: var(--accent); }
.bulk-textarea::placeholder { color: var(--text4); }
.bulk-empty { padding: 14px; font-size: 12px; color: var(--text3); text-align: center; background: var(--bg3); border: 1px dashed var(--border2); border-radius: 7px; margin-top: 12px; }
.bulk-preview-wrap { margin-top: 14px; background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.bulk-preview-title { padding: 10px 14px; font-size: 12px; font-weight: 600; color: var(--text2); border-bottom: 1px solid var(--border); }
.bulk-preview-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.bulk-preview-table thead th { padding: 7px 10px; font-size: 9px; font-weight: 700; color: var(--text3); letter-spacing: .07em; text-transform: uppercase; border-bottom: 1px solid var(--border); background: var(--bg2); text-align: left; }
.bulk-preview-table tbody td { padding: 7px 10px; color: var(--text2); border-bottom: 1px solid var(--border); }
.bulk-preview-table tbody tr:last-child td { border-bottom: none; }
.bulk-row-error { background: rgba(248, 113, 113, 0.05); }
.bulk-ok { color: var(--green); font-weight: 700; }
.bulk-bad { color: var(--red); font-weight: 700; }

/* ── HALF-DAY TOGGLE IN MODAL ── */
.half-day-toggle-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.half-day-toggle { display: flex; border: 1px solid var(--border2); border-radius: 7px; overflow: hidden; }
.hdt-btn {
  padding: 6px 16px; font-size: 12px; font-weight: 600;
  background: var(--bg3); color: var(--text3);
  border: none; cursor: pointer; font-family: inherit;
  transition: background .12s, color .12s;
}
.hdt-btn.hdt-active { background: var(--accent); color: #fff; }

/* ── HALF-DAY BADGE (in leave history / recent leaves) ── */
.half-day-badge {
  display: inline-block; font-size: 9px; font-weight: 700;
  padding: 1px 5px; border-radius: 20px;
  background: var(--amber-bg); color: var(--amber);
  letter-spacing: .03em; vertical-align: middle; margin-left: 3px;
}

/* ── EDIT LEAVE MODAL (list of records) ── */
.el-list { display: flex; flex-direction: column; gap: 8px; }
.el-row { background: var(--bg3); border: 1px solid var(--border); border-radius: 9px; overflow: hidden; }
.el-row-main { display: flex; align-items: center; gap: 14px; padding: 12px 14px; cursor: default; }
.el-date  { font-size: 12px; font-weight: 600; color: var(--text); min-width: 130px; }
.el-type  { font-size: 12px; color: var(--text2); min-width: 130px; }
.el-reason { font-size: 12px; color: var(--text3); flex: 1; }
.el-select-btn {
  background: var(--bg4); border: 1px solid var(--border2); color: var(--text2);
  font-size: 11px; font-weight: 600; padding: 4px 12px; border-radius: 5px;
  cursor: pointer; font-family: inherit; flex-shrink: 0;
}
.el-select-btn:hover { border-color: var(--accent); color: var(--accent-l); }
.el-edit-panel {
  border-top: 1px solid var(--border); background: var(--bg2);
  padding: 14px 16px;
}

/* ── LEAVE HISTORY TAB ── */
.lh-month { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; margin-bottom: 14px; overflow: hidden; }
.lh-month-hdr { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--border); background: var(--bg3); }
.lh-month-name { font-size: 13px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; }
.lh-current-tag {
  font-size: 9px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
  background: var(--accent-bg); color: var(--accent-l);
  padding: 2px 7px; border-radius: 20px;
}
.lh-month-collapsed .lh-month-hdr { border-bottom: none; }
.lh-month-total { font-size: 13px; font-weight: 600; color: var(--accent-l); }
.lh-row { display: flex; align-items: center; gap: 12px; padding: 10px 16px; border-bottom: 1px solid var(--border); }
.lh-row:last-child { border-bottom: none; }
.lh-date { font-size: 12px; font-weight: 600; color: var(--text2); min-width: 60px; }
.lh-type { min-width: 140px; }
.lh-reason { font-size: 12px; color: var(--text3); flex: 1; }

/* ── MONTHLY AVAILABILITY BANNER (in + modal) ── */
.monthly-avail {
  display: flex; align-items: center; gap: 14px;
  background: var(--accent-bg); border: 1px solid var(--accent);
  border-radius: 9px; padding: 12px 14px; margin-bottom: 16px;
}
.ma-num {
  font-size: 30px; font-weight: 800; color: var(--accent-l);
  line-height: 1; flex-shrink: 0;
}
.ma-info { flex: 1; min-width: 0; }
.ma-label {
  font-size: 12px; font-weight: 700; color: var(--accent-l);
  letter-spacing: .02em;
}
.ma-detail {
  font-size: 11px; color: var(--text2); margin-top: 3px; line-height: 1.4;
}

/* ── ROW CHECKBOX + EDIT-SELECTED BUTTON ── */
.row-check { width: 16px; height: 16px; cursor: pointer; accent-color: var(--accent); }
/* In dark theme, tell the browser to render checkboxes in their dark variant
   so the unchecked white background blends with the dark UI. */
:root[data-theme="dark"] .row-check { color-scheme: dark; }
.row-selected { background: var(--accent-bg) !important; }
.row-selected:hover { background: var(--accent-bg) !important; }
.btn-edit-selected:not(:disabled) { color: var(--accent-l); border-color: var(--accent); }
.btn-edit-selected:disabled { opacity: 0.4; cursor: not-allowed; color: var(--text3); border-color: var(--border2); }

/* ── DANGER ZONE inside Edit modal ── */
.danger-zone { border-top: 1px solid var(--border); margin-top: 18px; padding-top: 14px; }
.danger-zone-label { font-size: 10px; font-weight: 700; color: var(--text3); letter-spacing: .07em; text-transform: uppercase; margin-bottom: 8px; }
.danger-zone-btn {
  background: transparent; border: 1px solid rgba(248, 113, 113, .3);
  color: var(--red); padding: 8px 14px; border-radius: 7px;
  font-size: 12px; font-weight: 500; cursor: pointer; font-family: inherit;
}
.danger-zone-btn:hover { background: var(--red-bg); border-color: var(--red); }

/* ── INLINE CONFIRMATION (inside footer) ── */
.confirm-prompt { color: var(--text); }

/* ── DELETE CONFIRMATION ── */
.confirm-warn { display: flex; gap: 12px; align-items: flex-start; padding: 12px 14px; background: var(--red-bg); border: 1px solid rgba(248,113,113,.3); border-radius: 8px; margin-bottom: 12px; }
.confirm-warn-icon { font-size: 22px; color: var(--red); flex-shrink: 0; }
.confirm-warn-title { font-size: 14px; color: var(--text); font-weight: 600; margin-bottom: 3px; }
.confirm-warn-sub { font-size: 12px; color: var(--text3); }
.confirm-impact { background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; padding: 4px 14px; }
.confirm-impact-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; font-size: 12px; color: var(--text2); border-bottom: 1px solid var(--border); }
.confirm-impact-row:last-child { border-bottom: none; }
.confirm-impact-val { color: var(--red); font-weight: 600; }

/* ── POLICY SUMMARY + LEAVE TYPE CARDS ── */
.policy-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 13px; margin-bottom: 24px; }
.ps-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 15px 17px; }
.ps-num { font-size: 26px; font-weight: 700; }
.ps-lbl { font-size: 12px; color: var(--text2); margin-top: 5px; font-weight: 500; }
.ps-sub { font-size: 11px; color: var(--text3); margin-top: 2px; }

.policy-section-title {
  font-size: 13px; font-weight: 700; color: var(--text3);
  letter-spacing: .07em; text-transform: uppercase;
  margin: 24px 0 12px;
}

.leave-types-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.leave-type-card {
  background: var(--bg2); border: 1px solid var(--border);
  border-left: 3px solid var(--text3); border-radius: 10px;
  padding: 14px 16px;
}
.lt-hdr { display: flex; align-items: center; gap: 11px; margin-bottom: 8px; }
.lt-icon { font-size: 20px; }
.lt-title { font-size: 14px; font-weight: 700; color: var(--text); }
.lt-days { font-size: 12px; font-weight: 600; margin-top: 1px; }
.lt-headline { font-size: 13px; font-weight: 700; margin-top: 2px; }
.lt-annual { font-size: 12px; color: var(--text2); margin: 8px 0 4px; padding: 6px 9px; background: var(--bg3); border-radius: 6px; border-left: 2px solid var(--border2); }
.lt-annual strong { color: var(--text); }
.lt-credit { font-size: 12px; color: var(--text2); margin: 8px 0 6px; line-height: 1.5; }
.lt-eligibility { font-size: 11px; color: var(--text3); margin-bottom: 8px; }
.lt-eligibility strong { color: var(--text2); font-weight: 600; }
.policy-callout {
  background: var(--accent-bg); border: 1px solid var(--accent);
  border-radius: 8px; padding: 12px 16px; margin: 0 0 22px;
  font-size: 12px; color: var(--text2); line-height: 1.6;
}
.policy-callout strong { color: var(--accent-l); }
.policy-callout .lt-badge { vertical-align: middle; margin: 0 2px; }
.lt-badges { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 8px; }
.lt-badge {
  display: inline-block; font-size: 9px; font-weight: 700;
  padding: 2px 7px; border-radius: 20px;
  letter-spacing: .03em; text-transform: uppercase;
}
.lt-badge-deducts   { background: var(--accent-bg); color: var(--accent-l); }
.lt-badge-bonus     { background: var(--green-bg);  color: var(--green); }
.lt-badge-carry     { background: var(--purple-bg); color: var(--purple); }
.lt-badge-probation { background: var(--amber-bg);  color: var(--amber); }
.lt-notes {
  font-size: 11px; color: var(--text3); line-height: 1.5;
  margin-top: 6px; padding-top: 8px; border-top: 1px dashed var(--border);
}
.lt-notice {
  font-size: 11px; color: var(--accent-l); margin-top: 6px;
}

/* ── CULTURE & SATISFACTION TAB ── */
.culture-stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 13px; margin-bottom: 26px; }
.cs-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 16px 18px; }
.cs-card-high   { border-left: 3px solid var(--red); }
.cs-card-medium { border-left: 3px solid var(--amber); }
.cs-card-low    { border-left: 3px solid var(--green); }
.cs-card-team   { border-left: 3px solid var(--accent-l); }
.cs-num { font-size: 28px; font-weight: 700; color: var(--text); }
.cs-card-high   .cs-num { color: var(--red); }
.cs-card-medium .cs-num { color: var(--amber); }
.cs-card-low    .cs-num { color: var(--green); }
.cs-card-team   .cs-num { color: var(--accent-l); }
.cs-lbl { font-size: 11px; color: var(--text3); margin-top: 4px; font-weight: 500; }

.culture-section { margin-bottom: 28px; }
.culture-section-hdr { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 14px; gap: 14px; flex-wrap: wrap; }
.culture-section-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 3px; }
.culture-section-sub { font-size: 12px; color: var(--text3); max-width: 600px; }

.rec {
  display: flex; gap: 14px; padding: 14px 16px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 10px; margin-bottom: 10px;
}
.rec-high   { border-left: 3px solid var(--red); }
.rec-medium { border-left: 3px solid var(--amber); }
.rec-low    { border-left: 3px solid var(--green); }
.rec-side { flex-shrink: 0; }
.rec-icon { font-size: 18px; }
.rec-body { flex: 1; }
.rec-meta { display: flex; gap: 8px; align-items: center; margin-bottom: 6px; }
.rec-sev {
  font-size: 9px; font-weight: 700; padding: 2px 7px;
  border-radius: 20px; letter-spacing: .04em; text-transform: uppercase;
}
.rec-sev-high   { background: var(--red-bg); color: var(--red); }
.rec-sev-medium { background: var(--amber-bg); color: var(--amber); }
.rec-sev-low    { background: var(--green-bg); color: var(--green); }
.rec-cat { font-size: 11px; color: var(--text3); font-weight: 500; }
.rec-title { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 5px; }
.rec-text { font-size: 13px; color: var(--text2); line-height: 1.5; margin-bottom: 8px; }
.rec-action { font-size: 12px; color: var(--accent-l); }
.rec-action strong { color: var(--accent-l); font-weight: 600; }
.rec-empty { padding: 20px; text-align: center; font-size: 13px; color: var(--text3); background: var(--bg3); border-radius: 8px; border: 1px dashed var(--border2); }

.ai-output {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 10px; padding: 18px 20px; min-height: 100px;
}
.ai-empty, .ai-loading, .ai-error { font-size: 13px; color: var(--text2); line-height: 1.5; }
.ai-error { color: var(--red); }
.ai-error code { background: var(--bg3); padding: 1px 5px; border-radius: 3px; font-size: 11px; }
.ai-cached-note { font-size: 11px; color: var(--text3); margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px solid var(--border); }
.ai-rendered { font-size: 13px; color: var(--text2); line-height: 1.65; }
.ai-rendered strong { color: var(--text); }
.ai-rendered p { margin-bottom: 10px; }
.ai-list { list-style: none; padding: 0; margin: 0; }
.ai-list li {
  padding: 10px 0 12px; border-bottom: 1px solid var(--border);
  display: flex; gap: 10px; align-items: flex-start;
}
.ai-list li:last-child { border-bottom: none; }
.ai-num { color: var(--accent-l); font-weight: 700; flex-shrink: 0; min-width: 22px; }
