/* StaffDesk app.css
   Internal tool, system font stack (no CDN). Signature: warm amber for
   onboarding, slate blue for offboarding — the phase is always readable
   at a glance from the chips, KPIs and accents. */
:root {
  --bg: #f6f5f2;
  --card: #ffffff;
  --ink: #20242a;
  --muted: #6b7280;
  --line: #e3e1db;
  --brand: #1f3a33;        /* deep pine */
  --brand-ink: #ffffff;
  --onb: #b97718;          /* onboarding amber */
  --onb-bg: #fdf3e2;
  --offb: #3e5d8f;         /* offboarding slate */
  --offb-bg: #e9eef7;
  --ok: #2e7d4f;
  --ok-bg: #e7f3ec;
  --bad: #b3372f;
  --bad-bg: #fbeae8;
  --radius: 10px;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font: 15px/1.5 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
.wrap { max-width: 1080px; margin: 0 auto; padding: 0 1rem; }
a { color: var(--brand); }
h1 { font-size: 1.45rem; margin: 0; letter-spacing: -0.01em; }
h2 { font-size: 1.02rem; margin: 0 0 .6rem; text-transform: uppercase;
     letter-spacing: .06em; color: var(--muted); font-weight: 600; }
h3 { margin: 0 0 .25rem; }

/* top bar */
.topbar { background: var(--brand); color: var(--brand-ink); }
.topbar-in { display: flex; align-items: center; gap: 1.5rem; min-height: 54px; flex-wrap: wrap; }
.brand { color: #fff; text-decoration: none; font-weight: 700; font-size: 1.1rem; letter-spacing: .01em; }
.brand span { color: #d8b35c; }
.topbar nav { display: flex; gap: .25rem; }
.topbar nav a { color: #d8dcd9; text-decoration: none; padding: .35rem .7rem; border-radius: 6px; }
.topbar nav a.on, .topbar nav a:hover { background: rgba(255,255,255,.12); color: #fff; }
.who { margin-left: auto; display: flex; gap: .9rem; align-items: center; font-size: .88rem; color: #cfd6d2; }
.who a { color: #fff; }

main { padding: 1.2rem 1rem 2rem; }
.page-head { display: flex; align-items: center; justify-content: space-between;
             gap: 1rem; margin: .4rem 0 1rem; flex-wrap: wrap; }
.foot { color: var(--muted); font-size: .8rem; padding: 1rem; text-align: center; }

/* flash */
.flash { padding: .6rem .9rem; border-radius: var(--radius); margin: 0 0 1rem; }
.flash.ok { background: var(--ok-bg); color: var(--ok); }
.flash.bad { background: var(--bad-bg); color: var(--bad); }
.flash.secret { background: #fff8e1; border: 1px dashed var(--onb); color: #5d4a12; }

/* cards & tiles */
.card { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
        padding: 1rem 1.1rem; margin: 0 0 1rem; }
.tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: .9rem; }
.tile { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
        padding: 1rem 1.1rem; text-decoration: none; color: inherit; }
.tile:hover { border-color: var(--brand); }
.tile p { margin: .2rem 0 0; color: var(--muted); font-size: .88rem; }

/* KPIs */
.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: .9rem; margin-bottom: 1.4rem; }
.kpi { background: var(--card); border: 1px solid var(--line); border-left: 5px solid var(--brand);
       border-radius: var(--radius); padding: .8rem 1rem; text-decoration: none; color: inherit; }
.kpi em { display: block; font-style: normal; font-size: 1.7rem; font-weight: 700; }
.kpi span { color: var(--muted); font-size: .85rem; }
.kpi.onb { border-left-color: var(--onb); }
.kpi.offb { border-left-color: var(--offb); }
.kpi.quiet { border-left-color: var(--line); }

/* chips & statuses */
.chip { display: inline-block; padding: .1rem .55rem; border-radius: 999px; font-size: .76rem;
        background: #ecebe6; color: #4b5046; vertical-align: middle; }
.chip.onb { background: var(--onb-bg); color: var(--onb); }
.chip.offb { background: var(--offb-bg); color: var(--offb); }
.status { display: inline-block; padding: .12rem .55rem; border-radius: 6px; font-size: .78rem; vertical-align: middle; }
.s-open { background: var(--onb-bg); color: var(--onb); }
.s-awaiting_ack { background: #fff3cd; color: #8a6d1a; }
.s-completed { background: var(--ok-bg); color: var(--ok); }
.s-cancelled { background: #eee; color: var(--muted); }

/* tables */
.tbl { width: 100%; border-collapse: collapse; background: var(--card);
       border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; margin-bottom: 1.2rem; }
.tbl th { text-align: left; font-size: .78rem; text-transform: uppercase; letter-spacing: .05em;
          color: var(--muted); padding: .55rem .8rem; border-bottom: 1px solid var(--line); background: #fbfaf8; }
.tbl td { padding: .55rem .8rem; border-bottom: 1px solid var(--line); vertical-align: middle; }
.tbl tr:last-child td { border-bottom: none; }
.tbl tr.inactive td { opacity: .45; }
/* .row-actions retired in 1.2.1 — use .cell-actions inside a td instead */

/* buttons & forms */
.btn { display: inline-block; padding: .42rem .9rem; border-radius: 8px; border: 1px solid var(--line);
       background: #fff; color: var(--ink); font-size: .88rem; cursor: pointer; text-decoration: none; }
.btn:hover { border-color: var(--brand); }
.btn.primary { background: var(--brand); border-color: var(--brand); color: #fff; }
.btn.primary:hover { background: #2a4f45; }
.btn.primary:disabled { background: #9aada6; border-color: #9aada6; cursor: not-allowed; }
.btn.small { padding: .2rem .6rem; font-size: .8rem; }
.btn.wide { width: 100%; text-align: center; }
.btn.ok-btn { background: var(--ok); border-color: var(--ok); color: #fff; }
label { display: block; font-size: .85rem; color: var(--muted); margin-bottom: .6rem; }
input, select, textarea {
  display: block; width: 100%; margin-top: .2rem; padding: .45rem .6rem; font: inherit;
  border: 1px solid var(--line); border-radius: 8px; background: #fff; color: var(--ink);
}
input:focus, select:focus, textarea:focus, .btn:focus-visible { outline: 2px solid var(--brand); outline-offset: 1px; }
input:disabled, textarea:disabled { background: #f3f2ee; color: #777; }
.inline-form { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.inline-form input, .inline-form select { width: auto; margin: 0; }
.wrap-form { row-gap: .7rem; }
.filters { display: flex; gap: .5rem; margin-bottom: 1rem; flex-wrap: wrap; }
.filters select { width: auto; margin: 0; }
label.check { display: flex; gap: .5rem; align-items: flex-start; color: var(--ink); }
label.check input { width: auto; margin-top: .2rem; }

/* request form grid */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .2rem 1.2rem; }
.form-grid .span2 { grid-column: span 2; }
.actions-row { display: flex; gap: .6rem; }

/* request detail */
.cols { display: grid; grid-template-columns: 1.7fr 1fr; gap: 1rem; align-items: start; }
.col-side .card { position: relative; }
.item { display: grid; grid-template-columns: 1fr; gap: .35rem;
        border-top: 1px solid var(--line); padding: .6rem 0; }
.item:first-of-type { border-top: none; }
.item.done .item-label { color: var(--ok); }
.item.done .item-label::after { content: " ✓"; }
.item.na .item-label { color: var(--muted); text-decoration: line-through; }
.item-main { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.item-label { font-weight: 600; }
.item-label .req { color: var(--bad); }
.item-meta { color: var(--muted); font-size: .78rem; }
.item-value, .item-remarks { font-size: .85rem; }
.item-actions { display: flex; gap: .4rem; }
.side-form label { margin-bottom: .45rem; }
.contact { margin: .25rem 0; font-size: .9rem; }
.ack-link { display: block; background: #f3f2ee; padding: .5rem; border-radius: 6px;
            word-break: break-all; font-size: .82rem; margin: .3rem 0 .5rem; }
.small-note { font-size: .78rem; }
.mt { margin-top: .5rem; }
.muted { color: var(--muted); }
.empty { color: var(--muted); background: var(--card); border: 1px dashed var(--line);
         border-radius: var(--radius); padding: 1.2rem; text-align: center; }
.pw-change { margin-top: 1.5rem; color: var(--muted); }
.pw-change summary { cursor: pointer; }
.pw-change form { margin-top: .6rem; }

/* login & ack */
.ms-btn { display: flex; align-items: center; justify-content: center; gap: .55rem; }
.or-rule { display: flex; align-items: center; gap: .8rem; color: var(--muted);
           font-size: .8rem; margin: 1rem 0; }
.or-rule::before, .or-rule::after { content: ""; flex: 1; border-top: 1px solid var(--line); }
.login-card, .ack-card { max-width: 30rem; margin: 8vh auto 0; background: var(--card);
  border: 1px solid var(--line); border-radius: 14px; padding: 2rem; }
.ack-card { max-width: 38rem; margin-top: 4vh; }
.login-brand { font-size: 1.6rem; font-weight: 700; color: var(--brand); }
.login-brand span { color: #b8902f; }
.ack-dl { display: grid; grid-template-columns: auto 1fr; gap: .25rem 1rem; margin: 1rem 0; }
.ack-dl dt { color: var(--muted); }
.ack-dl dd { margin: 0; font-weight: 600; }
.ack-list { padding-left: 1.2rem; }
.ack-list li { margin: .2rem 0; }

@media (max-width: 860px) {
  .cols, .form-grid { grid-template-columns: 1fr; }
  .form-grid .span2 { grid-column: span 1; }
  .topbar-in { padding: .4rem 0; }
  .who { margin-left: 0; }
}
@media (prefers-reduced-motion: reduce) { * { transition: none !important; } }

/* v1.2.0 users page */
.chip.pend { background: #fff3cd; color: #8a6d1a; margin-left: .35rem; }
.btn.danger { color: var(--bad); border-color: #e7c2bf; }
.btn.danger:hover { border-color: var(--bad); }

/* v1.2.1 alignment fix: never set flex on <td> directly (breaks table-cell layout) */
.cell-actions { display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; }
.tbl td .inline-form { flex-wrap: nowrap; }
.tbl td .inline-form input[type="password"] { width: 11rem; min-width: 8rem; }
.tbl td .inline-form label.check { white-space: nowrap; font-size: .8rem; margin: 0; }
.tbl th { white-space: nowrap; }

/* v1.3.1 copier chips */
.chip.copier-colour {
  background: linear-gradient(90deg, #ffd9d9, #ffeccc, #fdf6c8, #d8f3d8, #d5e8fa, #e6dcf7);
  color: #3a3a3a; border: 1px solid rgba(0,0,0,.06);
}
.chip.copier-bw { background: #e8e8e8; color: #444; }

/* v1.3.3 scrollable table + pager */
.tbl-scroll { max-height: 62vh; overflow-y: auto; border: 1px solid var(--line);
              border-radius: var(--radius); margin-bottom: 1rem; }
.tbl-scroll .tbl { border: none; border-radius: 0; margin-bottom: 0; }
.tbl-scroll thead th { position: sticky; top: 0; background: #fbfaf8; z-index: 1;
                       box-shadow: 0 1px 0 var(--line); }
.pager { display: flex; gap: .35rem; align-items: center; flex-wrap: wrap; margin-bottom: 1.2rem; }
.pager .pg-on { background: var(--brand); border-color: var(--brand); color: #fff; }
.pager .disabled { pointer-events: none; opacity: .4; }

/* v1.5.0 entity colour chips + entity checkbox picker */
.chip-entity { color: #2c3230; }
.entity-picks { border: 1px solid var(--line); border-radius: 8px; padding: .6rem .8rem; margin: .4rem 0 .8rem; }
.entity-picks legend { font-size: .8rem; color: var(--muted); padding: 0 .3rem; }
.entity-picks label.check { display: inline-flex; align-items: center; gap: .35rem; margin: 0 .9rem .3rem 0; }

/* v1.6.0 sign-offs */
.signoff { margin: .4rem 0; }

/* v1.7.0 RO directory typeahead */
.ro-wrap { position: relative; }
.ro-menu { position: absolute; z-index: 20; left: 0; right: 0; background: #fff;
           border: 1px solid var(--line); border-radius: 8px; margin-top: 2px;
           box-shadow: 0 4px 14px rgba(0,0,0,.08); max-height: 14rem; overflow-y: auto; }
.ro-item { display: block; width: 100%; text-align: left; padding: .45rem .7rem;
           border: none; background: none; font: inherit; cursor: pointer; }
.ro-item:hover { background: #f3f2ee; }

/* v1.7.1 drag reorder */
.drag-handle { cursor: grab; color: var(--muted); user-select: none; width: 1.4rem; text-align: center; }
tr.dragging { opacity: .5; }

/* v1.8.0 notes thread + on hold */
.s-on_hold { background: #efe3f3; color: #6d3f86; }
.kpi.hold { border-left-color: #9a6cb0; }
.notes-thread { margin-bottom: .8rem; }
.note { border-top: 1px solid var(--line); padding: .5rem 0; }
.note:first-child { border-top: none; }
.note-meta { font-size: .76rem; color: var(--muted); }
.note-text { white-space: pre-wrap; }
.note-form textarea { margin-bottom: .4rem; }
details > summary.btn { list-style: none; text-align: center; cursor: pointer; }
details > summary.btn::-webkit-details-marker { display: none; }

/* v1.8.1 picker error */
.ro-error { padding: .45rem .7rem; color: var(--bad); font-size: .85rem; }

/* v1.9.0 read-only detail cards */
.kv { display: grid; grid-template-columns: 9rem 1fr; gap: .25rem .6rem; margin: 0; }
.kv dt { color: var(--muted); font-size: .82rem; }
.kv dd { margin: 0; }
.card h2 .btn.small { float: right; }
.role-links .btn { margin-right: .3rem; }

/* v1.9.1 read-only item values for other roles */
.item-ro { font-size: .88rem; padding: .15rem 0; }

/* v1.10.0 asset picker */
.ad-wrap { position: relative; }
