:root {
  --bg: #f4f6f9; --card: #fff; --ink: #1c2530; --muted: #6b7787;
  --line: #e2e7ee; --accent: #e8730c; --accent-d: #c95f06;
  --ok: #1f9d57; --warn: #d98a00; --bad: #d23c3c;
}
* { box-sizing: border-box; }
body { margin: 0; font: 14px/1.45 -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg); color: var(--ink); }

.topbar { display: flex; align-items: center; gap: 24px; padding: 0 18px;
  background: #fff; border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 5; }
.brand { font-weight: 700; font-size: 16px; padding: 14px 0; white-space: nowrap; }
.tabs { display: flex; gap: 4px; }
.tab { border: 0; background: none; padding: 16px 14px; cursor: pointer; color: var(--muted);
  font-size: 14px; border-bottom: 2px solid transparent; }
.tab:hover { color: var(--ink); }
.tab.active { color: var(--accent-d); border-bottom-color: var(--accent); font-weight: 600; }

.filters { display: flex; flex-wrap: wrap; gap: 12px; align-items: end; padding: 14px 18px;
  background: var(--card); border-bottom: 1px solid var(--line); position: sticky; top: 49px; z-index: 4; }
.filters label { display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--muted); }
.filters input, .filters select { padding: 7px 9px; border: 1px solid var(--line); border-radius: 7px;
  font-size: 14px; background: #fff; color: var(--ink); }
.filters input:focus, .filters select:focus { outline: 2px solid #f3c89a; border-color: var(--accent); }
button.primary { background: var(--accent); color: #fff; border: 0; }
button.primary:hover { background: var(--accent-d); }
.filters button { padding: 8px 14px; border: 1px solid var(--line); background: #fff; border-radius: 7px;
  cursor: pointer; font-size: 14px; height: 35px; }
.filters button:hover { border-color: var(--accent); }
.filters button.primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.filters button.primary:hover { background: var(--accent-d); border-color: var(--accent-d); }
.status { color: var(--muted); font-size: 13px; align-self: center; }

main { padding: 16px 18px 60px; }
.hint { color: var(--muted); padding: 40px; text-align: center; }

table { border-collapse: collapse; width: 100%; background: var(--card); font-size: 13px;
  border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
th, td { padding: 7px 10px; text-align: left; border-bottom: 1px solid var(--line); white-space: nowrap; }
thead th { background: #f0f3f7; position: sticky; top: 0; font-weight: 600; font-size: 12px;
  color: var(--muted); z-index: 2; }

/* любая таблица — в своём контейнере со скроллом, заголовок липнет к его верху */
.table-wrap { overflow: auto; max-height: calc(100vh - 165px); border: 1px solid var(--line); border-radius: 10px; }
.table-wrap > table { border: 0; border-radius: 0; }
tbody tr:hover { background: #fbf6f0; }
td.num { text-align: right; font-variant-numeric: tabular-nums; }
.cell-time { font-variant-numeric: tabular-nums; }
.warn-cell { color: var(--bad); }
.muted { color: var(--muted); }
.badge { display: inline-block; padding: 1px 7px; border-radius: 20px; font-size: 11px; }
.badge.in { background: #e3f5ea; color: var(--ok); }
.badge.out { background: #fdeede; color: var(--warn); }

/* сетка-график */
.grid-wrap { overflow: auto; max-height: calc(100vh - 170px); border: 1px solid var(--line); border-radius: 10px; }
/* заголовок липнет к верху СВОЕГО контейнера со скроллом, а не к окну */
.grid-wrap table.grid thead th { top: 0; }
table.grid td.day { text-align: center; font-variant-numeric: tabular-nums; min-width: 92px; }
table.grid td.name { position: sticky; left: 0; background: var(--card); font-weight: 500; z-index: 1; }
table.grid th.name { position: sticky; left: 0; z-index: 3; }
table.grid td.day.empty { color: #c4ccd6; }
.day-h { font-variant-numeric: tabular-nums; font-weight: 500; }
.wknd { background: #f7f3ee; }
.day .h { color: var(--muted); font-size: 11px; }

/* настройки */
.settings-card { background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  padding: 18px; max-width: 820px; }
.pt-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--line); }
.pt-row:last-child { border: 0; }
.pt-name { font-weight: 600; min-width: 240px; }
.pt-meta { color: var(--muted); font-size: 12px; }
.save-bar { margin-top: 16px; }
.user-form { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.user-form input, .user-form select { padding: 7px 9px; border: 1px solid var(--line); border-radius: 7px; font-size: 14px; }
.user-form .primary { background: var(--accent); color: #fff; border: 0; border-radius: 7px; padding: 8px 14px; cursor: pointer; }
.user-form .primary:hover { background: var(--accent-d); }
.u-del { border: 0; background: none; color: var(--bad); cursor: pointer; }
.u-edit { border: 0; background: none; color: var(--accent-d); cursor: pointer; }
.cap-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 6px 14px; margin: 12px 0; }
.cap { display: flex; align-items: center; gap: 7px; font-size: 14px; cursor: pointer; }
.cap input { width: 16px; height: 16px; }

/* шапка: пользователь */
.user { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.user .who { color: var(--muted); font-size: 13px; }
.user button { border: 1px solid var(--line); background: #fff; border-radius: 7px; padding: 5px 10px;
  cursor: pointer; font-size: 13px; }
.user button:hover { border-color: var(--accent); }

/* таблица смен */
#shifts { width: auto; }
#shifts input[type="text"], #shifts .sh-name { width: 160px; }
#shifts input { padding: 5px 7px; border: 1px solid var(--line); border-radius: 6px; }
.rm-shift { border: 0; background: none; color: var(--bad); cursor: pointer; font-size: 14px; }
#addShift { border: 1px solid var(--line); background: #fff; border-radius: 7px; padding: 6px 12px; cursor: pointer; }
#addShift:hover { border-color: var(--accent); }

tfoot td { font-weight: 600; background: #f0f3f7; border-top: 2px solid var(--line); }

/* выгрузка ЗУП */
.zup-bar { display: flex; align-items: center; gap: 10px; padding: 10px 2px 12px; flex-wrap: wrap; }
.zup-bar .primary { background: var(--accent); color: #fff; border: 0; border-radius: 7px; padding: 8px 14px; cursor: pointer; }
.zup-bar .primary:hover { background: var(--accent-d); }
.selp, #selAll { width: 16px; height: 16px; cursor: pointer; }

/* табло «на объектах» */
tr.zone-row td { background: #fbf3ea; font-weight: 700; color: var(--ink); font-size: 13px; }

/* страница входа */
.login-body { display: flex; align-items: center; justify-content: center; height: 100vh; }
.login-card { background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 28px 30px;
  display: flex; flex-direction: column; gap: 14px; width: 320px; box-shadow: 0 8px 30px rgba(0,0,0,.07); }
.login-brand { font-weight: 700; font-size: 17px; text-align: center; margin-bottom: 6px; }
.login-card label { display: flex; flex-direction: column; gap: 5px; font-size: 12px; color: var(--muted); }
.login-card input { padding: 9px 11px; border: 1px solid var(--line); border-radius: 8px; font-size: 15px; }
.login-card input:focus { outline: 2px solid #f3c89a; border-color: var(--accent); }
.login-card button.primary { background: var(--accent); color: #fff; border: 0; border-radius: 8px;
  padding: 10px; font-size: 15px; cursor: pointer; }
.login-card button.primary:hover { background: var(--accent-d); }
.login-err { color: var(--bad); font-size: 13px; min-height: 16px; text-align: center; }

/* метки/бейджи */
.mk { display: inline-block; padding: 0 6px; border-radius: 10px; font-size: 11px; line-height: 16px;
  margin: 1px 2px 1px 0; white-space: nowrap; }
.mk.late { background: #fde7e7; color: var(--bad); }
.mk.early { background: #fff3df; color: var(--warn); }
.mk.bad { background: #fde7e7; color: var(--bad); }
.mk.man { background: #e7eefb; color: #2f5bd0; }
.mk.alco { background: #fbe3e3; color: #b81e1e; font-weight: 600; }
.late-t { color: var(--bad); }
.early-t { color: var(--warn); }
.grid .day { cursor: pointer; }
.grid .day .mk { font-size: 10px; padding: 0 4px; }
.marks-cell { cursor: pointer; min-width: 200px; }
.edit-mk { border: 0; background: none; cursor: pointer; color: var(--muted); opacity: 0; }
tr:hover .edit-mk { opacity: 1; }

/* модалка пометок */
.modal { position: fixed; inset: 0; background: rgba(20,28,38,.45); display: flex;
  align-items: center; justify-content: center; z-index: 50; }
.modal.hidden { display: none; }
.modal-card { background: #fff; border-radius: 14px; padding: 20px 22px; width: 440px; max-width: 92vw;
  box-shadow: 0 12px 40px rgba(0,0,0,.2); }
.modal-head { font-size: 15px; margin-bottom: 12px; display: flex; align-items: center; }
.modal-x { margin-left: auto; border: 0; background: none; font-size: 16px; cursor: pointer; color: var(--muted); }
.modal-notes { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px;
  max-height: 200px; overflow: auto; }
.note-row { display: flex; align-items: center; gap: 8px; }
.note-by { color: var(--muted); font-size: 11px; margin-left: auto; }
.note-del { border: 0; background: none; color: var(--bad); cursor: pointer; }
.modal-quick { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.modal-quick .q, #qAlc { border: 1px solid var(--line); background: #fff; border-radius: 16px;
  padding: 5px 12px; cursor: pointer; font-size: 13px; }
.modal-quick .q:hover, #qAlc:hover { border-color: var(--accent); background: #fff7f0; }
.modal-row { display: flex; gap: 8px; margin-top: 8px; }
.modal-row input { flex: 1; padding: 7px 10px; border: 1px solid var(--line); border-radius: 8px; font-size: 14px; }
.modal-row .primary { border: 0; border-radius: 8px; padding: 7px 16px; cursor: pointer; }
