/* ============================================================
   MX Drive · InSync365 — shared styling (ported from ATS module)
   Namespace: .mx-*
   Sits ON TOP of colors_and_type.css + insync-tables.css.
   ============================================================ */

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--is-font-sans);
  color: var(--is-fg-1);
  background: var(--is-bg-app);
  -webkit-font-smoothing: antialiased;
}

/* ── Page shell ────────────────────────────────────────────── */
.mx-screen { padding: 22px 28px 60px; max-width: 1600px; margin: 0 auto; }

/* ── Page header ───────────────────────────────────────────── */
.mx-pagehead { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.mx-pagehead__left { min-width: 0; }
.mx-pagehead__crumb { display: flex; gap: 6px; align-items: center; font: 500 12px var(--is-font-sans); color: var(--is-fg-3); margin-bottom: 4px; }
.mx-pagehead__crumb i { font-size: 9px; }
.mx-pagehead__crumb a { color: var(--is-fg-3); text-decoration: none; }
.mx-pagehead__crumb a:hover { color: var(--is-brand-blue); }
.mx-pagehead h1 {
  font: 700 26px/1.15 var(--is-font-sans);
  letter-spacing: -.01em;
  color: var(--is-fg-1);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.mx-pagehead h1 .mx-newchip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 20px;
  padding: 2px 9px;
  border-radius: 999px;
  background: var(--is-brand-blue-100);
  color: var(--is-brand-blue-700);
  border: 1px solid #cfe4f4;
  font: 700 10px var(--is-font-sans);
  letter-spacing: .05em;
  text-transform: uppercase;
  line-height: 1;
}
.mx-pagehead h1 .mx-newchip i { font-size: 9px; }
.mx-pagehead__count {
  font: 600 13px var(--is-font-sans);
  color: var(--is-fg-2);
  background: var(--is-bg-surface-3);
  border: 1px solid var(--is-border-1);
  padding: 2px 10px;
  border-radius: 999px;
}
.mx-pagehead__sub { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.mx-pagehead__sub-text { font: 500 13px var(--is-font-sans); color: var(--is-fg-3); }
.mx-pagehead__sub-text b { color: var(--is-fg-1); font-weight: 700; }
.mx-pagehead__actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* ── Performance pill (UNIVERSAL pattern) ──────────────────── */
.mx-loadchip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 22px;
  padding: 0 9px;
  border-radius: 999px;
  background: var(--is-bg-surface-3);
  border: 1px solid var(--is-border-1);
  font: 600 11px var(--is-font-mono);
  color: var(--is-fg-3);
  cursor: default;
  transition: background .15s, border-color .15s, color .15s;
  user-select: none;
}
.mx-loadchip:hover { background: #fff; color: var(--is-fg-1); border-color: var(--is-border-2); }
.mx-loadchip i { font-size: 9px; color: var(--is-fg-3); }
.mx-loadchip:hover i { color: var(--is-action-blue); }
.mx-loadchip b { color: var(--is-fg-2); font-weight: 600; }
.mx-loadchip:hover b { color: var(--is-fg-1); }
.mx-loadchip__sep { color: #aab1ba; font-weight: 400; padding: 0 1px; }
.mx-loadchip.is-slow { background: rgba(206, 134, 0, .08); border-color: rgba(206, 134, 0, .25); color: var(--is-warning); }

/* ── V1↔V2 link ────────────────────────────────────────────── */
.mx-vlink {
  font: 500 12px var(--is-font-sans);
  color: var(--is-fg-3);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px dashed var(--is-border-2);
  cursor: pointer;
  background: transparent;
  transition: background .15s, color .15s, border-color .15s;
}
.mx-vlink i { font-size: 10px; }
.mx-vlink:hover { color: var(--is-brand-blue); border-color: var(--is-brand-blue); background: var(--is-brand-blue-100); border-style: solid; }

/* ── Buttons ───────────────────────────────────────────────── */
.mx-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 36px;
  padding: 0 14px;
  border-radius: var(--is-radius-sm);
  border: 1px solid transparent;
  font: 600 13px var(--is-font-sans);
  cursor: pointer;
  white-space: nowrap;
  transition: background .12s, color .12s, border-color .12s;
  text-decoration: none;
}
.mx-btn i { font-size: 12px; }
.mx-btn--primary { background: var(--is-brand-blue); color: #fff; border-color: var(--is-brand-blue); }
.mx-btn--primary:hover { background: var(--is-brand-blue-700); border-color: var(--is-brand-blue-700); }
.mx-btn--ghost { background: #fff; color: var(--is-fg-2); border-color: var(--is-border-3); }
.mx-btn--ghost:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.mx-btn--danger { background: var(--is-danger); color: #fff; border-color: var(--is-danger); }
.mx-btn--danger:hover { filter: brightness(.92); }
.mx-btn--ghost-danger { background: #fff; color: var(--is-danger); border-color: rgba(217,44,44,.3); }
.mx-btn--ghost-danger:hover { background: var(--is-danger-bg); }
.mx-btn--ghost-success { background: #fff; color: var(--is-success); border-color: rgba(38,176,80,.35); }
.mx-btn--ghost-success:hover { background: rgba(38,176,80,.06); }
.mx-btn--sm { height: 30px; padding: 0 10px; font-size: 12px; }
.mx-btn:disabled { opacity: .5; cursor: not-allowed; }

.mx-iconbtn {
  width: 30px;
  height: 30px;
  border-radius: var(--is-radius-sm);
  border: 1px solid var(--is-border-2);
  background: #fff;
  color: var(--is-fg-2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  transition: background .12s, color .12s, border-color .12s;
}
.mx-iconbtn:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.mx-iconbtn.is-danger:hover { background: var(--is-danger-bg); color: var(--is-danger); border-color: rgba(217,44,44,.3); }

/* ── Filter bar ────────────────────────────────────────────── */
.mx-filterbar {
  background: var(--is-bg-surface);
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
  box-shadow: var(--is-shadow-1);
  padding: 12px 14px;
  margin-bottom: 10px;
}
.mx-filterbar__row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.mx-search { position: relative; flex: 1 1 320px; min-width: 240px; max-width: 460px; }
.mx-search > i { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--is-fg-3); font-size: 13px; }
.mx-search input {
  width: 100%;
  height: 36px;
  padding: 0 12px 0 34px;
  border: 1px solid var(--is-border-3);
  border-radius: var(--is-radius-sm);
  background: #fff;
  font: 400 13.5px var(--is-font-sans);
  color: var(--is-fg-1);
}
.mx-search input:focus { outline: none; border-color: var(--is-action-blue); box-shadow: 0 0 0 3px rgba(0,123,255,.15); }
.mx-search input::placeholder { color: var(--is-fg-muted); }

.mx-pill {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 36px;
  padding: 0 12px;
  border-radius: var(--is-radius-sm);
  border: 1px solid var(--is-border-3);
  background: #fff;
  font: 600 12.5px var(--is-font-sans);
  color: var(--is-fg-2);
  cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
  white-space: nowrap;
}
.mx-pill:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.mx-pill i.mx-pill__chev { font-size: 9px; color: var(--is-fg-3); }
.mx-pill.is-active { background: var(--is-brand-blue-100); border-color: #cfe4f4; color: var(--is-brand-blue-700); }
.mx-pill.is-active i.mx-pill__chev { color: var(--is-brand-blue-700); }
.mx-pill__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 16px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--is-brand-blue);
  color: #fff;
  font: 700 10px var(--is-font-sans);
}
.mx-pill.is-rank { border-style: solid; border-color: var(--is-brand-orange); color: var(--is-brand-orange-600); background: var(--is-brand-orange-100); }
.mx-pill.is-rank:hover { background: #fde6c5; }

.mx-spacer { flex: 1; }

/* ── Active filter chip strip ──────────────────────────────── */
.mx-chipstrip {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--is-border-1);
}
.mx-chipstrip__label { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; margin-right: 4px; }
.mx-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 24px;
  padding: 0 4px 0 9px;
  border-radius: 999px;
  background: var(--is-bg-surface-3);
  border: 1px solid var(--is-border-1);
  font: 600 12px var(--is-font-sans);
  color: var(--is-fg-1);
}
.mx-chip i.mx-chip__lead { font-size: 10px; color: var(--is-fg-3); }
.mx-chip b { font-weight: 700; }
.mx-chip__close {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: transparent;
  border: 0;
  color: var(--is-fg-3);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
}
.mx-chip__close:hover { background: var(--is-border-2); color: var(--is-fg-1); }
.mx-chipstrip__clear { margin-left: auto; background: transparent; border: 0; font: 600 12px var(--is-font-sans); color: var(--is-action-blue); cursor: pointer; padding: 4px 6px; }
.mx-chipstrip__clear:hover { text-decoration: underline; }

/* ── Rank hint banner (shown when no position selected) ────── */
.mx-rankhint {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  margin-bottom: 10px;
  background: var(--is-warning-bg);
  border: 1px solid #f0d77a;
  border-radius: var(--is-radius-sm);
  font: 500 12.5px var(--is-font-sans);
  color: #7a5a00;
}
.mx-rankhint i { color: var(--is-warning); }
.mx-rankhint b { font-weight: 700; }
.mx-rankhint__close {
  margin-left: auto;
  width: 24px;
  height: 24px;
  border: 0;
  background: transparent;
  border-radius: 999px;
  color: #7a5a00;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.mx-rankhint__close:hover { background: rgba(122,90,0,.1); }

/* ── Selection bar ─────────────────────────────────────────── */
.mx-selectbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--is-brand-blue-100);
  border: 1px solid #cfe4f4;
  border-radius: var(--is-radius-md);
  margin-bottom: 10px;
}
.mx-selectbar__left { display: flex; align-items: center; gap: 10px; font: 600 13px var(--is-font-sans); color: var(--is-brand-blue-700); }
.mx-selectbar__left input { accent-color: var(--is-brand-blue); width: 16px; height: 16px; }
.mx-selectbar__right { display: flex; align-items: center; gap: 8px; }
.mx-selectbar__btn {
  background: #fff;
  border: 1px solid #cfe4f4;
  color: var(--is-brand-blue-700);
  font: 600 12px var(--is-font-sans);
  height: 30px;
  padding: 0 10px;
  border-radius: 6px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.mx-selectbar__btn:hover { background: var(--is-brand-blue-100); }

/* ── Popover (dropdown) ────────────────────────────────────── */
.mx-popover {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 240px;
  max-width: 320px;
  background: #fff;
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
  box-shadow: 0 10px 32px rgba(20,28,50,.12), 0 2px 6px rgba(20,28,50,.06);
  padding: 6px;
  z-index: 50;
}
.mx-popover__head {
  padding: 6px 10px 4px;
  font: 700 11px var(--is-font-sans);
  color: var(--is-fg-3);
  text-transform: uppercase;
  letter-spacing: .05em;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.mx-popover__opt {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 6px;
  cursor: pointer;
  font: 500 13px var(--is-font-sans);
  color: var(--is-fg-1);
}
.mx-popover__opt:hover { background: var(--is-bg-surface-3); }
.mx-popover__opt input { accent-color: var(--is-brand-blue); margin: 0; }
.mx-popover__foot { display: flex; justify-content: space-between; padding: 6px 8px; border-top: 1px solid var(--is-border-1); margin-top: 4px; }
.mx-popover__foot button { background: transparent; border: 0; cursor: pointer; font: 600 12px var(--is-font-sans); color: var(--is-action-blue); padding: 4px 6px; }
.mx-popover__foot button:hover { text-decoration: underline; }
.mx-popover-backdrop { position: fixed; inset: 0; z-index: 40; background: transparent; }

/* ── Table card overrides ──────────────────────────────────── */
.mx-tablecard {
  background: var(--is-bg-surface);
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
  box-shadow: var(--is-shadow-1);
  overflow: clip;
}
.mx-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 14px;
  border-bottom: 1px solid var(--is-border-1);
  font: 500 12px var(--is-font-sans);
  color: var(--is-fg-3);
  gap: 16px;
  flex-wrap: wrap;
}
.mx-toolbar b { color: var(--is-fg-1); font-weight: 700; }
.mx-toolbar__left { display: flex; align-items: center; gap: 12px; }
.mx-toolbar__right { display: flex; align-items: center; gap: 8px; }

table.mx-table { width: 100%; border-collapse: separate; border-spacing: 0; table-layout: fixed; }
.mx-table thead th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: var(--is-bg-surface-3);
  font: 600 10.5px var(--is-font-sans);
  color: var(--is-fg-3);
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 8px 10px;
  text-align: left;
  border-bottom: 1px solid var(--is-border-1);
  white-space: nowrap;
  user-select: none;
  box-shadow: 0 1px 0 var(--is-border-1), 0 2px 6px rgba(20,28,50,.04);
}
.mx-table thead th .mx-th { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; }
.mx-table thead th .mx-th i { font-size: 9px; opacity: 0; transition: opacity .15s, color .15s; color: var(--is-fg-3); }
.mx-table thead th .mx-th:hover i { opacity: .6; }
.mx-table thead th .mx-th.is-sorted i { opacity: 1; color: var(--is-action-blue); }
.mx-table tbody tr { transition: background .12s; }
.mx-table tbody tr:hover { background: rgba(0,123,255,.04); }
.mx-table tbody tr.is-blacklisted { background: rgba(217,44,44,.04); }
.mx-table tbody tr.is-blacklisted:hover { background: rgba(217,44,44,.07); }
.mx-table tbody tr + tr td { border-top: 1px solid var(--is-border-1); }
.mx-table tbody td {
  padding: 10px 10px;
  vertical-align: top;
  font: 500 12.5px var(--is-font-sans);
  color: var(--is-fg-1);
  overflow: hidden;
}

/* ── Badges (status pills) ─────────────────────────────────── */
.mx-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  font: 600 11px var(--is-font-sans);
  white-space: nowrap;
  line-height: 1;
}
.mx-badge i { font-size: 8.5px; }
.mx-badge--blue { background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); border: 1px solid #cfe4f4; }
.mx-badge--orange { background: var(--is-brand-orange-100); color: #9a5b14; border: 1px solid #fad7a8; }
.mx-badge--purple { background: #efe6f5; color: #5c1a73; border: 1px solid #d9c5e5; }
.mx-badge--green { background: var(--is-success-bg); color: #1a7a3a; border: 1px solid #b8e3c5; }
.mx-badge--yellow { background: var(--is-warning-bg); color: #7a5a00; border: 1px solid #f0d77a; }
.mx-badge--red { background: var(--is-danger-bg); color: #a31e1e; border: 1px solid #f3b8b8; }
.mx-badge--gray { background: var(--is-bg-surface-3); color: var(--is-fg-2); border: 1px solid var(--is-border-1); }
.mx-badge--solid-green { background: var(--is-success); color: #fff; border: 1px solid var(--is-success); }
.mx-badge--solid-gray { background: var(--is-fg-muted); color: #fff; border: 1px solid var(--is-fg-muted); }

/* HR recommendation badge */
.mx-hrbadge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--is-brand-orange-100);
  color: var(--is-brand-orange-600);
  border: 1px solid #fad7a8;
  font: 700 10px var(--is-font-sans);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1;
}
.mx-hrbadge i { font-size: 9px; }

/* ── Card layout (<1200px) ─────────────────────────────────── */
.mx-table-wrap { display: block; }
.mx-cards-wrap { display: none; }
@media (max-width: 1199px) {
  .mx-table-wrap { display: block; overflow-x: auto; }
  .mx-cards-wrap { display: none; }
}
.mx-cards { display: flex; flex-direction: column; gap: 8px; padding: 12px; }
.mx-card {
  background: #fff;
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
  display: flex;
  flex-direction: column;
  transition: border-color .12s, box-shadow .12s;
  overflow: hidden;
}
.mx-card:hover { border-color: var(--is-border-2); box-shadow: var(--is-shadow-1); }
.mx-card__head { display: flex; align-items: center; gap: 10px; padding: 10px 12px; flex-wrap: wrap; }
.mx-card__title { font: 700 14px var(--is-font-sans); color: var(--is-fg-1); flex: 1; min-width: 0; }
.mx-card__title a { color: var(--is-brand-blue-700); text-decoration: none; }
.mx-card__title a:hover { text-decoration: underline; }
.mx-card__meta { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px 16px; padding: 8px 12px 10px 12px; border-top: 1px dashed var(--is-border-1); }
@media (max-width: 760px) { .mx-card__meta { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 420px) { .mx-card__meta { grid-template-columns: 1fr; } }
.mx-card__field { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mx-card__field-label { font: 500 9.5px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; }
.mx-card__field-value { font: 500 12.5px var(--is-font-sans); color: var(--is-fg-1); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mx-card__foot { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; border-top: 1px dashed var(--is-border-1); background: var(--is-bg-surface); }

/* ── Pagination ────────────────────────────────────────────── */
.mx-pager { display: flex; align-items: center; justify-content: space-between; padding: 8px 14px; border-top: 1px solid var(--is-border-1); background: var(--is-bg-surface); gap: 16px; flex-wrap: wrap; }
.mx-pager__info { font: 500 12px var(--is-font-sans); color: var(--is-fg-3); }
.mx-pager__info b { color: var(--is-fg-1); font-weight: 700; }
.mx-pager__pages { display: inline-flex; gap: 3px; align-items: center; }
.mx-pager button { height: 28px; min-width: 28px; padding: 0 8px; border-radius: var(--is-radius-sm); border: 1px solid var(--is-border-2); background: #fff; font: 600 12px var(--is-font-sans); color: var(--is-fg-2); cursor: pointer; }
.mx-pager button:hover:not(:disabled) { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.mx-pager button.is-active { background: var(--is-brand-blue); border-color: var(--is-brand-blue); color: #fff; }
.mx-pager button:disabled { opacity: .35; cursor: not-allowed; }

/* ── Forms ─────────────────────────────────────────────────── */
.mx-card-panel {
  background: var(--is-bg-surface);
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
  box-shadow: var(--is-shadow-1);
  overflow: hidden;
}
.mx-card-panel__head {
  padding: 14px 18px;
  border-bottom: 1px solid var(--is-border-1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.mx-card-panel__head h3 {
  margin: 0;
  font: 700 14px var(--is-font-sans);
  color: var(--is-fg-1);
  display: flex;
  align-items: center;
  gap: 8px;
}
.mx-card-panel__head h3 i { color: var(--is-fg-3); font-size: 13px; }
.mx-card-panel__body { padding: 16px 18px; }
.mx-card-panel__sub { font: 500 12px var(--is-font-sans); color: var(--is-fg-3); }

.mx-formsec { padding: 18px 0; border-bottom: 1px solid var(--is-border-1); }
.mx-formsec:last-child { border-bottom: 0; }
.mx-formsec__title { font: 700 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .06em; margin: 0 0 12px 0; display: flex; align-items: center; gap: 8px; }
.mx-formsec__title i { font-size: 11px; }

.mx-formrow { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 12px; }
.mx-formrow--3 { grid-template-columns: 1fr 1fr 1fr; }
.mx-formrow--1 { grid-template-columns: 1fr; }
@media (max-width: 740px) { .mx-formrow, .mx-formrow--3 { grid-template-columns: 1fr; } }

.mx-field { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.mx-field__label { font: 500 12px var(--is-font-sans); color: var(--is-fg-2); display: flex; align-items: center; gap: 4px; }
.mx-field__label .mx-req { color: var(--is-danger); font-weight: 700; }
.mx-field__help { font: 500 11.5px var(--is-font-sans); color: var(--is-fg-3); margin-top: 3px; }
.mx-field__help a { color: var(--is-brand-blue); font-weight: 600; text-decoration: none; }
.mx-field__help a:hover { text-decoration: underline; }
.mx-input, .mx-select, .mx-textarea {
  width: 100%;
  height: 36px;
  padding: 0 12px;
  border: 1px solid var(--is-border-3);
  border-radius: var(--is-radius-sm);
  background: #fff;
  font: 500 13px var(--is-font-sans);
  color: var(--is-fg-1);
  appearance: none;
}
.mx-textarea { height: auto; min-height: 80px; padding: 9px 12px; resize: vertical; font-family: var(--is-font-sans); }
.mx-select {
  padding-right: 30px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M3 5l3 3 3-3' stroke='%2376767E' fill='none' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 8px center;
}
.mx-input:focus, .mx-select:focus, .mx-textarea:focus { outline: none; border-color: var(--is-action-blue); box-shadow: 0 0 0 3px rgba(0,123,255,.15); }

/* Multi-select (chips inside a control) */
.mx-multi {
  width: 100%;
  min-height: 36px;
  padding: 4px 36px 4px 8px;
  border: 1px solid var(--is-border-3);
  border-radius: var(--is-radius-sm);
  background: #fff;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  position: relative;
  cursor: pointer;
  font: 500 13px var(--is-font-sans);
}
.mx-multi:hover { border-color: var(--is-border-2); }
.mx-multi:focus-within { border-color: var(--is-action-blue); box-shadow: 0 0 0 3px rgba(0,123,255,.15); }
.mx-multi__placeholder { color: var(--is-fg-muted); padding: 0 6px; }
.mx-multi__tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 22px;
  padding: 0 4px 0 8px;
  background: var(--is-brand-blue-100);
  color: var(--is-brand-blue-700);
  border: 1px solid #cfe4f4;
  border-radius: 999px;
  font: 600 11.5px var(--is-font-sans);
}
.mx-multi__tag-x { width: 16px; height: 16px; border-radius: 999px; background: transparent; border: 0; color: inherit; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; font-size: 8.5px; }
.mx-multi__tag-x:hover { background: rgba(6,104,148,.15); }
.mx-multi__chev {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 10px;
  color: var(--is-fg-3);
  pointer-events: none;
}

/* Toggle / switch (used in registries) */
.mx-toggle { position: relative; display: inline-block; width: 36px; height: 20px; }
.mx-toggle input { opacity: 0; width: 0; height: 0; }
.mx-toggle__slider {
  position: absolute;
  inset: 0;
  background: var(--is-border-3);
  border-radius: 999px;
  cursor: pointer;
  transition: background .15s;
}
.mx-toggle__slider::before {
  content: "";
  position: absolute;
  height: 14px;
  width: 14px;
  left: 3px;
  bottom: 3px;
  background: #fff;
  border-radius: 999px;
  transition: transform .15s;
}
.mx-toggle input:checked + .mx-toggle__slider { background: var(--is-brand-blue); }
.mx-toggle input:checked + .mx-toggle__slider::before { transform: translateX(16px); }

/* ── Tabs (used in details + registries) ───────────────────── */
.mx-tabs {
  background: var(--is-bg-surface);
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
  padding: 4px;
  box-shadow: var(--is-shadow-1);
  display: flex;
  gap: 2px;
  overflow-x: auto;
  margin-bottom: 14px;
}
.mx-tab {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  padding: 8px 14px;
  font: 600 13px var(--is-font-sans);
  color: var(--is-fg-2);
  cursor: pointer;
  border-radius: 8px;
  white-space: nowrap;
  border: 0;
  background: transparent;
  transition: background .15s, color .15s;
}
.mx-tab i { font-size: 13px; color: var(--is-fg-3); }
.mx-tab:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.mx-tab:hover i { color: var(--is-fg-1); }
.mx-tab.is-active { background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); }
.mx-tab.is-active i { color: var(--is-brand-blue); }
.mx-tab__count {
  font: 700 10.5px var(--is-font-sans);
  background: var(--is-bg-surface-3);
  color: var(--is-fg-3);
  padding: 1px 7px;
  border-radius: 999px;
  min-width: 18px;
  text-align: center;
}
.mx-tab.is-active .mx-tab__count { background: rgba(255,255,255,.7); color: var(--is-brand-blue-700); }

/* ── Modal ─────────────────────────────────────────────────── */
.mx-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(20,28,50,.35);
  z-index: 90;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 60px 20px 20px;
  overflow-y: auto;
}
.mx-modal {
  background: #fff;
  border-radius: var(--is-radius-lg);
  box-shadow: 0 20px 60px rgba(20,28,50,.25);
  width: 100%;
  max-width: 600px;
  overflow: hidden;
}
.mx-modal--lg { max-width: 760px; }
.mx-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--is-border-1);
}
.mx-modal__head h2 { margin: 0; font: 700 16px var(--is-font-sans); color: var(--is-fg-1); display: flex; align-items: center; gap: 8px; }
.mx-modal__head h2 i { color: var(--is-fg-3); font-size: 14px; }
.mx-modal__close { width: 32px; height: 32px; border-radius: var(--is-radius-sm); border: 0; background: transparent; color: var(--is-fg-2); cursor: pointer; }
.mx-modal__close:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.mx-modal__body { padding: 18px 20px; }
.mx-modal__foot { display: flex; justify-content: flex-end; gap: 8px; padding: 14px 20px; border-top: 1px solid var(--is-border-1); background: var(--is-bg-surface); }

/* ── Skill row (compact list with level/score/bar) ─────────── */
.mx-skill { display: grid; grid-template-columns: 1fr 100px 60px 1fr 32px; gap: 12px; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--is-border-1); }
.mx-skill:last-of-type { border-bottom: 0; }
.mx-skill__name { font: 600 13px var(--is-font-sans); color: var(--is-fg-1); display: flex; align-items: center; gap: 8px; min-width: 0; }
.mx-skill__pts { font: 700 13px var(--is-font-mono); color: var(--is-brand-blue-700); text-align: right; font-variant-numeric: tabular-nums; }
.mx-skill__bar { height: 6px; background: var(--is-bg-surface-3); border-radius: 999px; overflow: hidden; }
.mx-skill__bar > div { height: 100%; background: linear-gradient(90deg, var(--is-brand-blue), var(--is-brand-blue-300)); border-radius: 999px; }
.mx-skill__head { display: grid; grid-template-columns: 1fr 100px 60px 1fr 32px; gap: 12px; font: 600 10.5px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; padding-bottom: 6px; border-bottom: 1px solid var(--is-border-1); margin-bottom: 6px; }

.mx-level-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  font: 700 11.5px var(--is-font-sans);
}
.mx-level-badge--1 { background: var(--is-bg-surface-3); color: var(--is-fg-3); border: 1px solid var(--is-border-1); }
.mx-level-badge--2 { background: var(--is-bg-surface-3); color: var(--is-fg-2); border: 1px solid var(--is-border-1); }
.mx-level-badge--3 { background: var(--is-warning-bg); color: #7a5a00; border: 1px solid #f0d77a; }
.mx-level-badge--4 { background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); border: 1px solid #cfe4f4; }
.mx-level-badge--5 { background: var(--is-success-bg); color: #1a7a3a; border: 1px solid #b8e3c5; }

/* ── Score widget (used on candidate details header) ───────── */
.mx-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: var(--is-bg-surface-3);
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
  padding: 14px 18px;
  min-width: 140px;
}
.mx-score__big { font: 700 36px/.95 var(--is-font-sans); color: var(--is-brand-blue-700); letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.mx-score__label { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .06em; }
.mx-score__pos { font: 600 11.5px var(--is-font-sans); color: var(--is-fg-2); }
.mx-score__bar { width: 100px; height: 6px; background: #fff; border-radius: 999px; overflow: hidden; }
.mx-score__bar > div { height: 100%; background: linear-gradient(90deg, var(--is-brand-blue), var(--is-brand-blue-300)); border-radius: 999px; }

/* ── Avatar (initials) ─────────────────────────────────────── */
.mx-avatar {
  border-radius: 999px;
  background: linear-gradient(135deg, var(--is-brand-blue) 0%, var(--is-brand-purple) 100%);
  color: #fff;
  font-family: var(--is-font-sans);
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: -.01em;
}

/* ── Detail row (label/value) ──────────────────────────────── */
.mx-detail-row {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--is-border-1);
  align-items: start;
}
.mx-detail-row:last-child { border-bottom: 0; }
.mx-detail-row__label { font: 500 12px var(--is-font-sans); color: var(--is-fg-3); }
.mx-detail-row__value { font: 500 13px var(--is-font-sans); color: var(--is-fg-1); display: flex; flex-wrap: wrap; gap: 4px; align-items: center; min-width: 0; word-break: break-word; }
.mx-detail-row__value .mx-badge { flex-shrink: 0; }
.mx-detail-row__value.is-mono { font-family: var(--is-font-mono); font-size: 12.5px; }

/* ── Comment feed ──────────────────────────────────────────── */
.mx-feed { display: flex; flex-direction: column; gap: 10px; }
.mx-feed__item {
  display: flex;
  gap: 12px;
  padding: 12px;
  background: var(--is-bg-surface-3);
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-sm);
}
.mx-feed__icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--is-border-1);
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--is-fg-2);
  font-size: 13px;
}
.mx-feed__body { flex: 1; min-width: 0; }
.mx-feed__meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.mx-feed__type { font: 700 11px var(--is-font-sans); color: var(--is-brand-blue-700); text-transform: uppercase; letter-spacing: .04em; }
.mx-feed__author { font: 600 12px var(--is-font-sans); color: var(--is-fg-1); }
.mx-feed__date { font: 500 11.5px var(--is-font-mono); color: var(--is-fg-3); }
.mx-feed__text { font: 500 13px/1.5 var(--is-font-sans); color: var(--is-fg-1); white-space: pre-wrap; word-break: break-word; }
.mx-feed__context { display: inline-flex; align-items: center; gap: 5px; margin-top: 6px; padding: 3px 8px; background: #fff; border: 1px solid var(--is-border-1); border-radius: 999px; font: 500 11px var(--is-font-sans); color: var(--is-fg-3); }
.mx-feed__context i { font-size: 9px; }

/* ── HR rec button ─────────────────────────────────────────── */
.mx-hrrec {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 22px;
  padding: 0 9px;
  border-radius: 999px;
  border: 1px solid var(--is-border-2);
  background: #fff;
  color: var(--is-fg-3);
  font: 600 11px var(--is-font-sans);
  cursor: pointer;
  letter-spacing: .03em;
  text-transform: uppercase;
  transition: all .15s;
}
.mx-hrrec:hover { border-color: var(--is-brand-orange); color: var(--is-brand-orange-600); background: var(--is-brand-orange-100); }
.mx-hrrec.is-on { border-color: var(--is-brand-orange); color: var(--is-brand-orange-600); background: var(--is-brand-orange-100); }
.mx-hrrec i { font-size: 9px; }

/* ── Document item ─────────────────────────────────────────── */
.mx-doc {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-sm);
  background: #fff;
  margin-bottom: 8px;
}
.mx-doc__icon {
  width: 38px;
  height: 38px;
  border-radius: var(--is-radius-sm);
  background: var(--is-brand-blue-100);
  color: var(--is-brand-blue-700);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}
.mx-doc__body { flex: 1; min-width: 0; }
.mx-doc__name { font: 600 13px var(--is-font-sans); color: var(--is-fg-1); }
.mx-doc__meta { font: 500 11.5px var(--is-font-mono); color: var(--is-fg-3); margin-top: 2px; }
.mx-doc__actions { display: flex; gap: 4px; }

.mx-uploadzone {
  border: 2px dashed var(--is-border-3);
  border-radius: var(--is-radius-md);
  padding: 30px 20px;
  text-align: center;
  color: var(--is-fg-2);
  cursor: pointer;
  transition: all .15s;
  margin-bottom: 18px;
}
.mx-uploadzone:hover { border-color: var(--is-brand-blue); background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); }
.mx-uploadzone i { font-size: 26px; color: var(--is-fg-3); display: block; margin-bottom: 8px; }
.mx-uploadzone:hover i { color: var(--is-brand-blue); }
.mx-uploadzone__title { font: 700 13px var(--is-font-sans); margin-bottom: 3px; }
.mx-uploadzone__sub { font: 500 11.5px var(--is-font-sans); color: var(--is-fg-3); }

/* ── Info banner ───────────────────────────────────────────── */
.mx-info {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  background: var(--is-info-bg);
  border: 1px solid #b8dff0;
  border-radius: var(--is-radius-sm);
  font: 500 12.5px/1.5 var(--is-font-sans);
  color: #0a5b8c;
  margin-bottom: 12px;
}
.mx-info i { color: var(--is-info); font-size: 13px; margin-top: 2px; flex-shrink: 0; }
.mx-info b { color: #064267; font-weight: 700; }
.mx-info a { color: var(--is-brand-blue); font-weight: 600; text-decoration: none; }
.mx-info a:hover { text-decoration: underline; }

/* ── Helpers ───────────────────────────────────────────────── */
.mx-trunc { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; display: block; }
.mx-mono { font-family: var(--is-font-mono); font-variant-numeric: tabular-nums; }
.mx-divider { border: 0; border-top: 1px solid var(--is-border-1); margin: 14px 0; }

/* ── Sidebar (simplified — matches insync365_app sidebar look) ─ */
.mx-sidebar {
  width: 232px;
  height: 100%;
  background: linear-gradient(178deg, var(--is-brand-blue) 0%, var(--is-brand-purple) 95%);
  color: #fff;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  position: relative;
}
.mx-sidebar__logo { padding: 18px 18px 14px; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid rgba(255,255,255,.10); }
.mx-sidebar__logo-mark { width: 32px; height: 32px; border-radius: 8px; background: rgba(255,255,255,.15); display: inline-flex; align-items: center; justify-content: center; font: 800 13px var(--is-font-sans); color: #fff; letter-spacing: -.02em; }
.mx-sidebar__logo-text { display: flex; flex-direction: column; min-width: 0; }
.mx-sidebar__logo-text b { font: 800 14px var(--is-font-sans); color: #fff; letter-spacing: -.01em; }
.mx-sidebar__logo-text small { font: 600 10px var(--is-font-sans); color: rgba(255,255,255,.7); text-transform: uppercase; letter-spacing: .08em; }

.mx-sidebar__section { padding: 14px 14px 4px; font: 700 10px var(--is-font-sans); color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .08em; }
.mx-sidebar__nav { display: flex; flex-direction: column; gap: 1px; padding: 0 8px; }
.mx-sidebar__nav a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  font: 600 13px var(--is-font-sans);
  border-radius: 6px;
  transition: background .12s, color .12s;
}
.mx-sidebar__nav a i { width: 18px; text-align: center; font-size: 13px; color: rgba(255,255,255,.65); }
.mx-sidebar__nav a:hover { background: rgba(255,255,255,.10); color: #fff; }
.mx-sidebar__nav a:hover i { color: #fff; }
.mx-sidebar__nav a.is-active { background: rgba(255,255,255,.20); color: #fff; }
.mx-sidebar__nav a.is-active i { color: #fff; }

.mx-shell { display: flex; width: 100%; min-height: 100%; }
.mx-shell__main { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.mx-topbar {
  height: 56px;
  background: #fff;
  border-bottom: 1px solid var(--is-border-1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  gap: 12px;
  flex-shrink: 0;
}
.mx-topbar__breadcrumb { display: flex; align-items: center; gap: 8px; font: 500 13px var(--is-font-sans); color: var(--is-fg-2); min-width: 0; }
.mx-topbar__breadcrumb a { color: var(--is-fg-3); text-decoration: none; }
.mx-topbar__breadcrumb a:hover { color: var(--is-brand-blue); }
.mx-topbar__breadcrumb i { font-size: 9px; color: var(--is-fg-muted); }
.mx-topbar__breadcrumb b { color: var(--is-fg-1); font-weight: 700; }
.mx-topbar__right { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.mx-topbar__user {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px 4px 4px;
  border-radius: 999px;
  background: var(--is-bg-surface-3);
  font: 600 12.5px var(--is-font-sans);
  color: var(--is-fg-1);
}
.mx-topbar__user .mx-avatar { width: 28px; height: 28px; font-size: 11px; }


/* ============================================================
   MX DRIVE — screen-specific additions (on top of ported shell)
   ============================================================ */

/* ── Stat tiles (dashboard + report) ───────────────────────── */
.mx-statgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px; }
@media (max-width: 1199px) { .mx-statgrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px)  { .mx-statgrid { grid-template-columns: 1fr; } }
.mx-stat {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 16px 18px; background: var(--is-bg-surface);
  border: 1px solid var(--is-border-1); border-radius: var(--is-radius-md);
  box-shadow: var(--is-shadow-1); min-width: 0;
}
.mx-stat__icon { width: 40px; height: 40px; border-radius: 10px; display: inline-flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); }
.mx-stat__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
.mx-stat__label { font: 600 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; }
.mx-stat__value { font: 700 26px/1.05 var(--is-font-sans); color: var(--is-fg-1); font-variant-numeric: tabular-nums; letter-spacing: -.01em; }
.mx-stat__sub { font: 500 11.5px var(--is-font-sans); color: var(--is-fg-3); margin-top: 2px; }
.mx-stat--warn    .mx-stat__icon { background: var(--is-warning-bg); color: #8a6500; }
.mx-stat--warn    .mx-stat__value { color: #8a6500; }
.mx-stat--danger  .mx-stat__icon { background: var(--is-danger-bg); color: var(--is-danger); }
.mx-stat--danger  .mx-stat__value { color: var(--is-danger); }
.mx-stat--success .mx-stat__icon { background: var(--is-success-bg); color: #1a7a3a; }
.mx-stat--success .mx-stat__value { color: #1a7a3a; }

/* ── Expiry pill (polica osiguranja 30d → 0d gradient) ─────── */
.mx-expiry {
  display: inline-flex; align-items: center; gap: 6px;
  height: 22px; padding: 0 9px; border-radius: 999px;
  font: 700 11.5px var(--is-font-sans); white-space: nowrap; line-height: 1;
  border: 1px solid transparent;
}
.mx-expiry__dot { width: 7px; height: 7px; border-radius: 999px; background: currentColor; flex-shrink: 0; }
.mx-expiry--ok { background: var(--is-success-bg); color: #1a7a3a; border-color: #b8e3c5; }
.mx-expiry--30 { background: var(--is-warning-bg); color: #7a5a00; border-color: #f0d77a; }
.mx-expiry--20 { background: var(--is-brand-orange-100); color: #9a5b14; border-color: #fad7a8; }
.mx-expiry--10 { background: #fde3c4; color: #8a4d10; border-color: #f6c485; }
.mx-expiry--5  { background: var(--is-danger-bg); color: #a31e1e; border-color: #f3b8b8; }
.mx-expiry--0  { background: var(--is-danger); color: #fff; border-color: var(--is-danger); }

/* ── Entity header (client / vehicle detail) ───────────────── */
.mx-entity {
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
  background: var(--is-bg-surface); border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md); box-shadow: var(--is-shadow-1);
  padding: 18px 22px; margin-bottom: 14px;
}
.mx-entity__avatar { width: 56px; height: 56px; border-radius: 14px; font: 800 20px var(--is-font-sans); }
.mx-entity__info { flex: 1; min-width: 0; }
.mx-entity__info h1 { font: 700 22px/1.15 var(--is-font-sans); letter-spacing: -.01em; color: var(--is-fg-1); margin: 0 0 6px; }
.mx-entity__meta { font: 500 12.5px var(--is-font-sans); color: var(--is-fg-3); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.mx-entity__meta .mx-mono { color: var(--is-fg-2); }
.mx-entity__badges { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.mx-entity__stats { display: flex; gap: 12px; flex-wrap: wrap; }
.mx-entity__stat {
  text-align: center; min-width: 86px; padding: 10px 16px;
  background: var(--is-bg-surface-3); border: 1px solid var(--is-border-1);
  border-radius: var(--is-radius-md);
}
.mx-entity__stat-big { font: 700 22px var(--is-font-sans); color: var(--is-fg-1); line-height: 1; font-variant-numeric: tabular-nums; }
.mx-entity__stat small { display: block; font: 600 10px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; margin-top: 6px; }
.mx-entity__stat.is-danger .mx-entity__stat-big { color: var(--is-danger); }

/* ── Detail two-column grid ────────────────────────────────── */
.mx-detail-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
@media (max-width: 860px) { .mx-detail-cols { grid-template-columns: 1fr; gap: 12px; } }
.mx-detail-group__title { font: 700 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .06em; margin: 0 0 8px; }

/* ── Numeric / money cells + table footer totals ───────────── */
.mx-num { font-variant-numeric: tabular-nums; text-align: right; }
.mx-table th.mx-num, .mx-table td.mx-num { text-align: right; }
.mx-money { font: 600 13px var(--is-font-mono); color: var(--is-fg-1); font-variant-numeric: tabular-nums; }
.mx-money--debt { color: var(--is-danger); font-weight: 700; }
.mx-table tfoot td { padding: 12px 10px; background: var(--is-bg-surface-3); border-top: 2px solid var(--is-border-2); font: 700 12.5px var(--is-font-sans); color: var(--is-fg-1); }
.mx-table tfoot td.mx-num { font-family: var(--is-font-mono); }
.mx-table tfoot td .mx-money--debt { font-family: var(--is-font-mono); }

/* ── History list (plate changes) ──────────────────────────── */
.mx-history { list-style: none; padding: 0; margin: 0; }
.mx-history li { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 9px 0; border-bottom: 1px dashed var(--is-border-1); font: 500 13px var(--is-font-sans); color: var(--is-fg-2); }
.mx-history li:last-child { border-bottom: 0; }
.mx-history .is-current { color: var(--is-brand-blue-700); font-weight: 700; }

/* ── Client-type radio cards (klijent unos) ────────────────── */
.mx-typecards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 620px) { .mx-typecards { grid-template-columns: 1fr; } }
.mx-typecard {
  display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px;
  border: 1px solid var(--is-border-2); border-radius: var(--is-radius-md);
  cursor: pointer; background: #fff; transition: border-color .12s, background .12s, box-shadow .12s;
}
.mx-typecard:hover { border-color: var(--is-border-3); }
.mx-typecard input { accent-color: var(--is-brand-blue); margin-top: 3px; width: 16px; height: 16px; }
.mx-typecard__title { font: 700 13.5px var(--is-font-sans); color: var(--is-fg-1); }
.mx-typecard__desc { font: 500 11.5px var(--is-font-sans); color: var(--is-fg-3); margin-top: 2px; }
.mx-typecard.is-on { border-color: var(--is-brand-blue); background: var(--is-brand-blue-100); box-shadow: 0 0 0 3px rgba(4,148,218,.10); }

/* ── Registration summary box ──────────────────────────────── */
.mx-sumbox { background: var(--is-bg-surface-3); border: 1px solid var(--is-border-1); border-radius: var(--is-radius-md); padding: 14px 18px; margin-top: 14px; }
.mx-sumbox__row { display: flex; align-items: center; justify-content: space-between; font: 500 13.5px var(--is-font-sans); color: var(--is-fg-2); padding: 3px 0; }
.mx-sumbox__row b { font: 600 13.5px var(--is-font-mono); color: var(--is-fg-1); }
.mx-sumbox__row--total { font-size: 15px; color: var(--is-fg-1); font-weight: 700; }
.mx-sumbox__row--total b { font-size: 16px; }
.mx-sumbox hr { border: 0; border-top: 1px solid var(--is-border-2); margin: 8px 0; }

/* ── AI scan split view ────────────────────────────────────── */
.mx-scan { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
@media (max-width: 1080px) { .mx-scan { grid-template-columns: 1fr; } }
.mx-scan__preview {
  background: linear-gradient(178deg, #20283c 0%, #141b2c 100%);
  border-radius: var(--is-radius-md); padding: 22px; min-height: 540px;
  display: flex; align-items: flex-start; justify-content: center;
}
.mx-scan__doc { background: #fff; color: #1a1f2e; border-radius: var(--is-radius-sm); box-shadow: 0 10px 30px rgba(0,0,0,.35); width: 100%; max-width: 380px; padding: 24px 22px; font: 400 12px/1.55 var(--is-font-sans); }
.mx-scan__doc h4 { font: 700 13px var(--is-font-sans); text-align: center; margin: 0 0 12px; padding-bottom: 10px; border-bottom: 1px solid #e6e9ef; text-transform: uppercase; letter-spacing: .02em; }
.mx-scan__doc .mx-drow { display: flex; justify-content: space-between; gap: 12px; padding: 2px 0; }
.mx-scan__doc .mx-drow span { color: #7a8395; }
.mx-scan__doc .mx-drow b { color: #1a1f2e; font-weight: 600; text-align: right; }
.mx-scan__doc .mx-dgroup { font: 700 11px var(--is-font-sans); text-transform: uppercase; letter-spacing: .05em; color: var(--is-brand-blue-700); margin: 10px 0 4px; }
.mx-scan__doc hr { border: 0; border-top: 1px dashed #e6e9ef; margin: 8px 0; }

.mx-match { display: flex; gap: 10px; align-items: flex-start; padding: 11px 14px; border-radius: var(--is-radius-sm); margin-bottom: 12px; font: 500 12.5px/1.5 var(--is-font-sans); }
.mx-match i { font-size: 14px; margin-top: 1px; flex-shrink: 0; }
.mx-match b { display: block; font-weight: 700; margin-bottom: 1px; }
.mx-match--ok { background: var(--is-success-bg); color: #1a7a3a; border: 1px solid #b8e3c5; }
.mx-match--ok i { color: var(--is-success); }
.mx-match--warn { background: var(--is-warning-bg); color: #7a5a00; border: 1px solid #f0d77a; }
.mx-match--warn i { color: var(--is-warning); }

.mx-pill-ai { display: inline-flex; align-items: center; gap: 4px; height: 18px; padding: 0 8px; border-radius: 999px; background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); border: 1px solid #cfe4f4; font: 700 9.5px var(--is-font-sans); text-transform: uppercase; letter-spacing: .05em; }

/* ── AI processing steps ───────────────────────────────────── */
.mx-proc { max-width: 380px; margin: 24px auto 0; text-align: left; }
.mx-proc__step { display: flex; align-items: center; gap: 12px; padding: 9px 0; font: 500 13px var(--is-font-sans); color: var(--is-fg-2); }
.mx-proc__step i { font-size: 14px; width: 18px; text-align: center; }
.mx-proc__step.is-done { color: var(--is-fg-1); }
.mx-proc__step.is-done i { color: var(--is-success); }
.mx-proc__step.is-active i { color: var(--is-brand-blue); }
.mx-proc__step.is-wait { color: var(--is-fg-muted); }
.mx-proc__step.is-wait i { color: var(--is-border-3); }

/* ── Input group (suffix unit) ─────────────────────────────── */
.mx-inputgroup { display: flex; }
.mx-inputgroup .mx-input { border-radius: var(--is-radius-sm) 0 0 var(--is-radius-sm); }
.mx-inputgroup__suffix { display: inline-flex; align-items: center; padding: 0 12px; border: 1px solid var(--is-border-3); border-left: 0; border-radius: 0 var(--is-radius-sm) var(--is-radius-sm) 0; background: var(--is-bg-surface-3); font: 600 12px var(--is-font-sans); color: var(--is-fg-3); white-space: nowrap; }

/* ── Card panel + body padding helpers ─────────────────────── */
.mx-screen-narrow { max-width: 940px; }
.mx-card-panel + .mx-card-panel { margin-top: 14px; }
.mx-link { color: var(--is-brand-blue-700); text-decoration: none; font-weight: 600; }
.mx-link:hover { text-decoration: underline; }
.mx-readonly { background: var(--is-bg-surface-3); color: var(--is-fg-2); }
.mx-tablecard__foot-link { text-align: center; padding: 12px 16px; border-top: 1px solid var(--is-border-1); }

/* ── Shell layout: fixed sidebar + scrollable main ─────────── */
html, body { height: 100%; }
.mx-shell { height: 100vh; overflow: hidden; }
.mx-sidebar { height: 100vh; }
.mx-shell__main { height: 100vh; overflow-y: auto; }
.mx-topbar { position: sticky; top: 0; z-index: 20; }
/* Pin table headers just under the 56px topbar */
.mx-table thead th { top: 56px; }

/* ── Toast ─────────────────────────────────────────────────── */
.mx-toast {
  position: fixed; bottom: 22px; right: 22px; z-index: 4000;
  display: flex; align-items: center; gap: 9px;
  background: var(--is-fg-1); color: #fff;
  padding: 12px 16px; border-radius: var(--is-radius-sm);
  font: 600 13px var(--is-font-sans); box-shadow: var(--is-shadow-pop);
  transform: translateY(80px); opacity: 0; pointer-events: none;
  transition: transform .25s cubic-bezier(.2,.8,.2,1), opacity .25s;
  border-left: 3px solid var(--is-brand-blue);
}
.mx-toast.is-show { transform: translateY(0); opacity: 1; }
.mx-toast i { font-size: 15px; }
.mx-toast--success { border-left-color: var(--is-success); }
.mx-toast--success i { color: #4ad07d; }
.mx-toast--error { border-left-color: var(--is-danger); }
.mx-toast--error i { color: #ff8585; }
.mx-toast--info i { color: var(--is-brand-blue-300); }
