/* ============================================================
 * AccessControlLogsV2 (.acl-*) — log viewer for badge swipes.
 * Inherits design tokens from insync-tokens.css; uses the
 * shared .is-tablecard/.is-table sticky-thead patterns by
 * shape but with `acl-` selectors so the legacy V1 page is
 * untouched.
 * ============================================================ */

/* Shell */
.acl-bg { background: var(--is-bg-app); min-height: 100vh; }
.acl-screen { padding: 22px 28px 60px; max-width: 1600px; font-family: var(--is-font-sans); }

/* Load chip */
.acl-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; user-select: none; transition: background .15s, border-color .15s, color .15s; }
.acl-loadchip:hover { background: #fff; color: var(--is-fg-1); border-color: var(--is-border-2); }
.acl-loadchip i { font-size: 9px; color: var(--is-fg-3); }
.acl-loadchip:hover i { color: var(--is-action-blue); }
.acl-loadchip b { color: var(--is-fg-2); font-weight: 600; }
.acl-loadchip:hover b { color: var(--is-fg-1); }
.acl-loadchip__sep { color: #aab1ba; font-weight: 400; padding: 0 1px; }
.acl-loadchip.is-slow { background: rgba(206, 134, 0, .08); border-color: rgba(206, 134, 0, .25); color: var(--is-warning); }
.acl-loadchip.is-slow b, .acl-loadchip.is-slow i { color: var(--is-warning); }

/* Page header */
.acl-pagehead { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.acl-pagehead__crumb { display: flex; gap: 6px; align-items: center; font: 500 12px var(--is-font-sans); color: var(--is-fg-3); margin-bottom: 4px; }
.acl-pagehead__crumb i { font-size: 9px; }
.acl-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; }
.acl-pagehead h1 .acl-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; }
.acl-pagehead h1 .acl-vchip--new { 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 var(--is-brand-blue-200); font: 700 10px var(--is-font-sans); letter-spacing: .05em; text-transform: uppercase; line-height: 1; }
.acl-pagehead__sub { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.acl-pagehead__sub-text { font: 500 13px var(--is-font-sans); color: var(--is-fg-3); }
.acl-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; }
.acl-vlink i { font-size: 10px; }
.acl-vlink:hover { color: var(--is-brand-blue); border-color: var(--is-brand-blue); background: var(--is-brand-blue-100); border-style: solid; text-decoration: none; }
.acl-pagehead__actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* Buttons */
.acl-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; transition: background .15s, color .15s, border-color .15s; white-space: nowrap; }
.acl-btn i { font-size: 12px; }
.acl-btn--primary { background: var(--is-brand-blue); color: #fff; border-color: var(--is-brand-blue); }
.acl-btn--primary:hover { background: var(--is-brand-blue-700); border-color: var(--is-brand-blue-700); color: #fff; }
.acl-btn--ghost { background: #fff; color: var(--is-fg-2); border-color: var(--is-border-3); }
.acl-btn--ghost:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.acl-btn--ghost-success { background: #fff; color: var(--is-success); border-color: rgba(45,140,82,.35); }
.acl-btn--ghost-success:hover { background: rgba(45,140,82,.06); color: var(--is-success); }

/* Stat cards */
.acl-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-bottom: 14px; }
@media (max-width: 880px) { .acl-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.acl-stat { background: var(--is-bg-surface); border: 1px solid var(--is-border-1); border-radius: var(--is-radius-md); padding: 12px 14px; display: flex; align-items: center; gap: 12px; transition: border-color .12s, box-shadow .12s; }
.acl-stat:hover { border-color: var(--is-border-2); }
.acl-stat__icon { width: 36px; height: 36px; border-radius: var(--is-radius-sm); display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.acl-stat__icon.is-blue   { background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); }
.acl-stat__icon.is-green  { background: rgba(45,140,82,.10); color: var(--is-success); }
.acl-stat__icon.is-purple { background: rgba(58,6,71,.08); color: var(--is-brand-purple); }
.acl-stat__icon.is-warn   { background: rgba(206,134,0,.10); color: var(--is-warning); }
.acl-stat__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.acl-stat__label { font: 600 10px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .06em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.acl-stat__value { font: 700 22px var(--is-font-sans); color: var(--is-fg-1); font-variant-numeric: tabular-nums; line-height: 1.1; }
.acl-stat__delta { font: 500 11px var(--is-font-mono); color: var(--is-fg-3); }
.acl-stat__delta.is-up { color: var(--is-success); }
.acl-stat__delta.is-down { color: var(--is-danger); }

/* Filter bar */
.acl-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; }
.acl-filterbar__row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* Search input */
.acl-search { position: relative; flex: 1 1 320px; min-width: 240px; display: inline-flex; align-items: center; box-sizing: border-box; }
.acl-search > i { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--is-fg-3); font-size: 13px; pointer-events: none; }
.acl-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); box-sizing: border-box; }
.acl-search input:focus { outline: none; border-color: var(--is-action-blue); box-shadow: 0 0 0 3px rgba(0,123,255,.15); }

/* Filter pill (used as a label-style wrapper around SfMultiSelect / date popover) */
.acl-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; box-sizing: border-box; vertical-align: middle; }
.acl-pill:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.acl-pill i.acl-pill__lead { font-size: 11px; color: var(--is-fg-3); }
.acl-pill i.acl-pill__chev { font-size: 9px; color: var(--is-fg-3); }
.acl-pill.is-active { background: var(--is-brand-blue-100); border-color: var(--is-brand-blue-200); color: var(--is-brand-blue-700); }
.acl-pill.is-active i.acl-pill__lead, .acl-pill.is-active i.acl-pill__chev { color: var(--is-brand-blue-700); }
.acl-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); }

/* SfMultiSelect-in-pill wrapper. Hides Syncfusion's default frame so the
   filter looks like a single pill with a popup. */
.acl-pill-host { position: relative; }
.acl-pill-host .e-multiselect.e-input-group { border: 0 !important; height: 36px; min-height: 36px; background: transparent !important; box-shadow: none !important; }
.acl-pill-host .e-multiselect.e-input-group::before,
.acl-pill-host .e-multiselect.e-input-group::after { display: none !important; }
.acl-pill-host .e-multiselect .e-chips-collection,
.acl-pill-host .e-multiselect .e-chips-close { display: none !important; }
.acl-pill-host .e-multiselect .e-multi-select-wrapper { padding: 0 !important; min-height: 36px !important; }

/* Toggle pill (Samo nedodijeljene) */
.acl-togglepill { 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; user-select: none; }
.acl-togglepill:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.acl-togglepill.is-on { background: rgba(206,134,0,.10); border-color: rgba(206,134,0,.35); color: var(--is-warning); }
.acl-togglepill i { font-size: 11px; }

.acl-spacer { flex: 1; }

/* Density toggle (small inline control) */
.acl-density { display: inline-flex; align-items: center; gap: 4px; border: 1px solid var(--is-border-2); border-radius: var(--is-radius-sm); padding: 2px; background: #fff; }
.acl-density button { height: 22px; padding: 0 8px; border: 0; background: transparent; font: 600 11px var(--is-font-sans); color: var(--is-fg-3); cursor: pointer; border-radius: 4px; }
.acl-density button.is-active { background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); }

/* Date range popover */
.acl-popover { position: absolute; top: calc(100% + 6px); left: 0; min-width: 240px; 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; }
.acl-popover.is-wide { min-width: 360px; }
.acl-popover__head { padding: 6px 10px 4px; font: 700 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; }
.acl-popover-backdrop { position: fixed; inset: 0; z-index: 40; background: transparent; }
.acl-dpop { padding: 6px; }
.acl-dpop__presets { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; margin-bottom: 6px; }
.acl-dpop__preset { background: transparent; border: 1px solid var(--is-border-2); border-radius: 6px; padding: 8px 10px; font: 500 12px var(--is-font-sans); color: var(--is-fg-1); cursor: pointer; text-align: left; transition: background .12s, border-color .12s; }
.acl-dpop__preset:hover { background: var(--is-bg-surface-3); border-color: var(--is-border-3); }
.acl-dpop__preset.is-active { background: var(--is-brand-blue-100); border-color: var(--is-brand-blue-200); color: var(--is-brand-blue-700); }
.acl-dpop__custom { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; padding-top: 6px; border-top: 1px solid var(--is-border-1); }
.acl-dpop__custom label { font: 500 10px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; display: block; margin-bottom: 3px; }
.acl-dpop__custom input { width: 100%; height: 30px; padding: 0 8px; border: 1px solid var(--is-border-3); border-radius: 6px; font: 500 12px var(--is-font-sans); color: var(--is-fg-1); }

/* Active filter chips strip */
.acl-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); }
.acl-chipstrip__label { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; margin-right: 4px; }
.acl-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); }
.acl-chip i.acl-chip__lead { font-size: 10px; color: var(--is-fg-3); }
.acl-chip b { font-weight: 700; color: var(--is-fg-1); }
.acl-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; padding: 0; }
.acl-chip__close:hover { background: var(--is-border-2); color: var(--is-fg-1); }
.acl-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; }
.acl-chipstrip__clear:hover { text-decoration: underline; }

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

/* Pager */
.acl-pager { display: inline-flex; align-items: center; gap: 8px; }
.acl-pager__pages { display: inline-flex; gap: 3px; align-items: center; }
.acl-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; display: inline-flex; align-items: center; justify-content: center; }
.acl-pager button:hover:not(:disabled) { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.acl-pager button.is-active { background: var(--is-brand-blue); border-color: var(--is-brand-blue); color: #fff; }
.acl-pager button:disabled { opacity: .35; cursor: not-allowed; }
.acl-pager__ellipsis { padding: 0 4px; color: var(--is-fg-3); }
.acl-pager__pagesize { display: inline-flex; align-items: center; gap: 6px; font: 500 12px var(--is-font-sans); color: var(--is-fg-3); }
.acl-pager__pagesize select { height: 28px; padding: 0 24px 0 8px; border: 1px solid var(--is-border-2); border-radius: var(--is-radius-sm); background: #fff; font: 600 12px var(--is-font-sans); color: var(--is-fg-1); appearance: none; 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 6px center; }
.acl-pager-foot { 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); flex-wrap: wrap; gap: 12px; }
.acl-pager-foot__info { font: 500 12px var(--is-font-sans); color: var(--is-fg-3); }
.acl-pager-foot__info b { color: var(--is-fg-1); font-weight: 700; }

/* Table */
table.acl-table { width: 100%; border-collapse: separate; border-spacing: 0; table-layout: fixed; }
.acl-table thead th { position: sticky; top: var(--is-topbar-h); 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: 9px 12px; 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); }
.acl-table thead th .acl-th { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; }
.acl-table thead th .acl-th i { font-size: 9px; opacity: 0; transition: opacity .15s, color .15s; color: var(--is-fg-3); }
.acl-table thead th .acl-th:hover i { opacity: .6; }
.acl-table thead th .acl-th.is-sorted i { opacity: 1; color: var(--is-action-blue); }
.acl-table tbody tr { transition: background .12s; cursor: pointer; }
.acl-table tbody tr:hover { background: rgba(0,123,255,.04); }
.acl-table tbody tr.is-active { background: rgba(0,123,255,.08); }
.acl-table tbody tr + tr td { border-top: 1px solid var(--is-border-1); }
.acl-table tbody td { padding: 8px 12px; vertical-align: middle; font: 500 12.5px var(--is-font-sans); color: var(--is-fg-1); height: 38px; }
.acl-table.is-dense tbody td { padding: 5px 12px; height: 30px; font-size: 12px; }
.acl-table.is-dense thead th { padding: 7px 12px; }

/* Time cell */
.acl-time { display: flex; flex-direction: column; line-height: 1.25; }
.acl-time__abs { font: 500 12.5px var(--is-font-mono); color: var(--is-fg-1); font-variant-numeric: tabular-nums; letter-spacing: .01em; }
.acl-time__rel { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); }
.acl-table.is-dense .acl-time__rel { display: none; }

/* Employee cell + avatar (8-gradient deterministic palette) */
.acl-emp { display: flex; align-items: center; gap: 8px; min-width: 0; width: 100%; }
.acl-avatar { flex-shrink: 0; width: 26px; height: 26px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; color: #fff; font: 700 10.5px var(--is-font-sans); letter-spacing: .03em; background: linear-gradient(135deg, #0494da 0%, #3a0647 100%); }
.acl-avatar.is-palette-0 { background: linear-gradient(135deg, #0494da 0%, #3a0647 100%); }
.acl-avatar.is-palette-1 { background: linear-gradient(135deg, #f59e2c 0%, #d97706 100%); }
.acl-avatar.is-palette-2 { background: linear-gradient(135deg, #2d8c52 0%, #1f6a3b 100%); }
.acl-avatar.is-palette-3 { background: linear-gradient(135deg, #9333ea 0%, #5b21b6 100%); }
.acl-avatar.is-palette-4 { background: linear-gradient(135deg, #dc2626 0%, #991b1b 100%); }
.acl-avatar.is-palette-5 { background: linear-gradient(135deg, #0891b2 0%, #155e75 100%); }
.acl-avatar.is-palette-6 { background: linear-gradient(135deg, #65a30d 0%, #3f6212 100%); }
.acl-avatar.is-palette-7 { background: linear-gradient(135deg, #db2777 0%, #9d174d 100%); }
.acl-avatar--ghost { background: var(--is-bg-surface-3); color: var(--is-warning); border: 1px dashed rgba(206,134,0,.4); }
.acl-emp__body { display: flex; flex-direction: column; min-width: 0; line-height: 1.2; }
.acl-emp__name { font: 600 12.5px var(--is-font-sans); color: var(--is-fg-1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.acl-emp__name a { color: var(--is-brand-blue-700); text-decoration: none; }
.acl-emp__name a:hover { text-decoration: underline; }
.acl-emp__name.is-unassigned { color: var(--is-warning); font-style: italic; font-weight: 500; display: inline-flex; align-items: center; gap: 6px; }
.acl-emp__dept { font: 500 10.5px var(--is-font-sans); color: var(--is-fg-3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.acl-table.is-dense .acl-emp__dept { display: none; }
.acl-table.is-dense .acl-avatar { width: 22px; height: 22px; font-size: 9.5px; }
.acl-unassigned-dot { width: 7px; height: 7px; border-radius: 999px; background: var(--is-warning); flex-shrink: 0; }

/* Card cell */
.acl-card { display: inline-flex; align-items: center; gap: 6px; font: 600 12.5px var(--is-font-mono); color: var(--is-fg-1); font-variant-numeric: tabular-nums; letter-spacing: .02em; }
.acl-card i { font-size: 11px; color: var(--is-fg-3); }

/* Device cell */
.acl-device { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; width: 100%; }
.acl-device__name { font: 600 12.5px var(--is-font-sans); color: var(--is-fg-1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.acl-device__mac  { font: 500 10.5px var(--is-font-mono); color: var(--is-fg-3); letter-spacing: .02em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.acl-table.is-dense .acl-device__mac { display: none; }
.acl-device__name i { color: var(--is-fg-3); font-size: 10px; margin-right: 5px; }

/* Action chip */
.acl-actchip { display: inline-flex; align-items: center; gap: 5px; height: 22px; padding: 0 9px; border-radius: 999px; font: 600 11px var(--is-font-sans); letter-spacing: .01em; }
.acl-actchip.is-official { background: var(--is-info-bg); color: var(--is-info); }
.acl-actchip.is-private  { background: rgba(58,6,71,.08); color: var(--is-brand-purple); }
.acl-actchip.is-break    { background: rgba(206,134,0,.12); color: var(--is-warning); }
.acl-actchip.is-denied   { background: var(--is-danger-bg); color: var(--is-danger); }
.acl-actchip i { font-size: 9px; }

/* Empty state */
.acl-empty { padding: 48px 24px; text-align: center; }
.acl-empty i { font-size: 28px; color: var(--is-fg-3); margin-bottom: 10px; display: block; }
.acl-empty__title { font: 700 16px var(--is-font-sans); color: var(--is-fg-1); margin-bottom: 4px; }
.acl-empty__body  { font: 500 13px var(--is-font-sans); color: var(--is-fg-3); margin-bottom: 14px; }

/* ── Detail drawer ───────────────────────────────────────────── */
/* z-index above the app shell's sticky top-row (site.css `.main .top-row`
   has z-index: 1000) so the drawer header (eyebrow + timestamp + name) isn't
   clipped by the topbar at the top of the viewport. */
.acl-drawer-backdrop { position: fixed; inset: 0; background: rgba(20,28,50,.32); z-index: 1990; opacity: 0; pointer-events: none; transition: opacity .2s; }
.acl-drawer-backdrop.is-open { opacity: 1; pointer-events: auto; }
.acl-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 520px; max-width: 96vw; background: #fff; box-shadow: -8px 0 32px rgba(20,28,50,.16); z-index: 2000; transform: translateX(100%); transition: transform .25s cubic-bezier(.2,.8,.2,1); display: flex; flex-direction: column; }
.acl-drawer.is-open { transform: translateX(0); }
.acl-drawer__head { display: flex; align-items: flex-start; justify-content: space-between; padding: 16px 20px 14px; border-bottom: 1px solid var(--is-border-1); gap: 12px; }
.acl-drawer__head h2 { font: 700 18px var(--is-font-mono); color: var(--is-fg-1); margin: 0; letter-spacing: .01em; font-variant-numeric: tabular-nums; }
.acl-drawer__head .acl-drawer__eyebrow { font: 600 10.5px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 4px; display: inline-flex; align-items: center; gap: 6px; }
.acl-drawer__head .acl-drawer__eyebrow i { font-size: 10px; }
.acl-drawer__head-name { display: flex; align-items: center; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.acl-drawer__head-name-text { font: 700 14px var(--is-font-sans); color: var(--is-fg-1); }
.acl-drawer__head-name-text.is-unassigned { color: var(--is-warning); font-style: italic; font-weight: 500; }
.acl-drawer__head-name-dept { font: 500 12px var(--is-font-sans); color: var(--is-fg-3); }
.acl-drawer__head-sub { font: 500 12.5px var(--is-font-sans); color: var(--is-fg-3); margin-top: 6px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.acl-drawer__close { width: 32px; height: 32px; border-radius: var(--is-radius-sm); border: 0; background: transparent; color: var(--is-fg-2); cursor: pointer; flex-shrink: 0; }
.acl-drawer__close:hover { background: var(--is-bg-surface-3); color: var(--is-fg-1); }
.acl-drawer__body { flex: 1; overflow-y: auto; padding: 4px 0 20px; }
.acl-drawer__section { padding: 14px 20px; border-bottom: 1px solid var(--is-border-1); }
.acl-drawer__section:last-child { border-bottom: 0; }
.acl-drawer__section h3 { font: 700 10.5px 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; }
.acl-drawer__section h3 i { font-size: 11px; color: var(--is-fg-3); }
.acl-drawer__section-note { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); margin-top: -6px; margin-bottom: 10px; font-style: italic; }
.acl-kv { display: grid; grid-template-columns: 110px 1fr; gap: 4px 14px; }
.acl-kv__k { font: 600 11.5px var(--is-font-sans); color: var(--is-fg-3); padding: 4px 0; }
.acl-kv__v { font: 500 13px var(--is-font-sans); color: var(--is-fg-1); padding: 4px 0; word-break: break-word; }
.acl-kv__v.is-mono { font-family: var(--is-font-mono); font-variant-numeric: tabular-nums; }
.acl-kv__v.is-muted { color: var(--is-fg-3); }
.acl-kv__v a { color: var(--is-brand-blue-700); text-decoration: none; }
.acl-kv__v a:hover { text-decoration: underline; }
.acl-kv__v .is-unassigned { color: var(--is-warning); font-style: italic; font-weight: 500; display: inline-flex; align-items: center; gap: 6px; }

/* Neighbor timeline */
.acl-timeline { list-style: none; padding: 0; margin: 0; position: relative; }
.acl-timeline::before { content: ''; position: absolute; left: 11px; top: 6px; bottom: 6px; width: 1px; background: var(--is-border-2); }
.acl-tl { display: flex; gap: 12px; padding: 6px 0; position: relative; }
.acl-tl__dot { width: 23px; flex-shrink: 0; display: flex; justify-content: center; padding-top: 4px; }
.acl-tl__dot span { width: 9px; height: 9px; border-radius: 999px; background: var(--is-bg-surface); border: 2px solid var(--is-border-2); position: relative; z-index: 1; }
.acl-tl.is-current .acl-tl__dot span { background: var(--is-brand-blue); border-color: var(--is-brand-blue); box-shadow: 0 0 0 3px rgba(4,148,218,.18); }
.acl-tl.is-unassigned .acl-tl__dot span { background: var(--is-warning); border-color: var(--is-warning); }
.acl-tl__body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; padding: 2px 0; }
.acl-tl__head { display: flex; align-items: center; gap: 8px; font: 500 12px var(--is-font-mono); color: var(--is-fg-2); font-variant-numeric: tabular-nums; flex-wrap: wrap; }
.acl-tl__head b { font: 700 12.5px var(--is-font-sans); color: var(--is-fg-1); }
.acl-tl.is-unassigned .acl-tl__head b { color: var(--is-warning); font-style: italic; font-weight: 500; }
.acl-tl__current { font: 600 10px var(--is-font-sans); color: var(--is-brand-blue-700); background: var(--is-brand-blue-100); padding: 1px 7px; border-radius: 999px; text-transform: uppercase; letter-spacing: .05em; }
.acl-tl__meta { font: 500 11.5px var(--is-font-sans); color: var(--is-fg-3); }
.acl-tl__meta .acl-tl__card { font-family: var(--is-font-mono); color: var(--is-fg-2); }

/* Drawer footer */
.acl-drawer__foot { display: flex; gap: 8px; padding: 14px 20px; border-top: 1px solid var(--is-border-1); background: var(--is-bg-surface); }
.acl-drawer__foot .acl-btn { flex: 1; justify-content: center; }
