/* EVENT86 UI v20
   Единый слой интерфейса без изменения бизнес-логики и схемы данных. */
:root {
  --v20-sidebar: 236px;
  --v20-content: 1480px;
  --v20-radius: 12px;
  --v20-radius-sm: 9px;
  --v20-space-1: 4px;
  --v20-space-2: 8px;
  --v20-space-3: 12px;
  --v20-space-4: 16px;
  --v20-space-5: 20px;
  --v20-space-6: 24px;
  --v20-space-8: 32px;
}

body[data-ui-version="20"] {
  --ui-bg: #0f1115;
  --ui-sidebar: #0b0d10;
  --ui-surface: #171a20;
  --ui-surface-raised: #1c2027;
  --ui-surface-soft: #13161b;
  --ui-border: #2a3039;
  --ui-border-soft: #222831;
  --ui-text: #f1f3f5;
  --ui-muted: #98a2b3;
  --ui-brand: #e31e24;
  --ui-brand-soft: rgba(227,30,36,.12);
  --ui-primary: #e31e24;
  --ui-primary-strong: #f2373d;
  --ui-accent-text: #ff6267;
  --ui-primary-text: #ffffff;
  --ui-success: #5bc58a;
  --ui-warning: #e7b85d;
  --ui-danger: #ff857a;
  --ui-focus: rgba(227,30,36,.34);
  background: var(--ui-bg);
  color: var(--ui-text);
  font-size: 14px;
  line-height: 1.45;
}
body[data-ui-version="20"][data-theme="light"] {
  --ui-bg: #f4f5f7;
  --ui-sidebar: #ffffff;
  --ui-surface: #ffffff;
  --ui-surface-raised: #ffffff;
  --ui-surface-soft: #f8f9fb;
  --ui-border: #d9dee7;
  --ui-border-soft: #e8ebf0;
  --ui-text: #171a20;
  --ui-muted: #667085;
  --ui-brand: #e31e24;
  --ui-brand-soft: rgba(227,30,36,.09);
  --ui-primary: #e31e24;
  --ui-primary-strong: #c91920;
  --ui-accent-text: #c91920;
  --ui-primary-text: #ffffff;
  --ui-success: #18794e;
  --ui-warning: #9a6700;
  --ui-danger: #9f2d25;
  --ui-focus: rgba(227,30,36,.22);
}

body[data-ui-version="20"] *,
body[data-ui-version="20"] *::before,
body[data-ui-version="20"] *::after { box-sizing: border-box; }
body[data-ui-version="20"] a { text-underline-offset: 3px; }
body[data-ui-version="20"] :focus-visible { outline: 3px solid var(--ui-focus); outline-offset: 2px; }
body[data-ui-version="20"] h1,
body[data-ui-version="20"] h2,
body[data-ui-version="20"] h3 { color: var(--ui-text); letter-spacing: -.02em; }
body[data-ui-version="20"] h1 { font-size: clamp(26px, 2.4vw, 36px); line-height: 1.08; margin: 0; }
body[data-ui-version="20"] h2 { font-size: 20px; line-height: 1.2; }
body[data-ui-version="20"] .muted { color: var(--ui-muted) !important; }
body[data-ui-version="20"] .small-text { font-size: 12px; }

/* Layout and navigation */
body[data-ui-version="20"] .layout { grid-template-columns: var(--v20-sidebar) minmax(0,1fr); min-height: 100vh; }
body[data-ui-version="20"] .sidebar {
  width: var(--v20-sidebar);
  background: var(--ui-sidebar);
  border-right: 1px solid var(--ui-border-soft);
  padding: 18px 12px 14px;
  overflow-y: auto;
  scrollbar-width: thin;
}
body[data-ui-version="20"] .brand-block { padding: 4px 10px 16px; margin: 0 0 6px; }
body[data-ui-version="20"] .brand { font-size: 20px; letter-spacing: .02em; }
body[data-ui-version="20"] .brand-subtitle { color: var(--ui-muted); font-size: 11px; margin-top: 2px; }
body[data-ui-version="20"] .nav-grouped { display: grid; gap: 14px; }
body[data-ui-version="20"] .nav-group { display: grid; gap: 3px; }
body[data-ui-version="20"] .nav-group-label {
  color: var(--ui-muted);
  font-size: 10px;
  font-weight: 750;
  letter-spacing: .11em;
  text-transform: uppercase;
  padding: 4px 10px 5px;
}
body[data-ui-version="20"] .nav-link {
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: 9px;
  color: var(--ui-muted);
  font-size: 13px;
  font-weight: 620;
  gap: 10px;
}
body[data-ui-version="20"] .nav-link:hover { color: var(--ui-text); background: var(--ui-surface-soft); border-color: var(--ui-border-soft); }
body[data-ui-version="20"] .nav-link.active {
  color: var(--ui-text);
  background: color-mix(in srgb, var(--ui-brand) 9%, var(--ui-surface-raised));
  border-color: color-mix(in srgb, var(--ui-brand) 24%, var(--ui-border));
  box-shadow: inset 3px 0 0 var(--ui-brand);
}
body[data-ui-version="20"] .nav-link.active::before { display: none; }
body[data-ui-version="20"] .nav-icon { width: 18px; height: 18px; opacity: .78; }
body[data-ui-version="20"] .nav-link.active .nav-icon { color: var(--ui-accent-text); opacity: 1; }
body[data-ui-version="20"] .sidebar-presence-disclosure {
  margin: 16px 4px 8px;
  padding: 0;
  border: 0;
  background: transparent;
}
body[data-ui-version="20"] .sidebar-presence-disclosure summary {
  min-height: 34px;
  padding: 7px 8px;
  border-radius: 8px;
  color: var(--ui-muted);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  font-size: 12px;
}
body[data-ui-version="20"] .sidebar-presence-disclosure summary:hover { background: var(--ui-surface-soft); }
body[data-ui-version="20"] .sidebar-presence-disclosure .presence-list { padding: 4px 8px 0 24px; }
body[data-ui-version="20"] .sidebar-user {
  margin-top: auto;
  padding: 14px 8px 2px;
  border-top: 1px solid var(--ui-border-soft);
  gap: 10px;
}
body[data-ui-version="20"] .sidebar-user .user-name { font-size: 13px; }
body[data-ui-version="20"] .sidebar-logout { color: var(--ui-muted); font-size: 12px; text-decoration: none; }
body[data-ui-version="20"] .sidebar-logout:hover { color: var(--ui-danger); }
body[data-ui-version="20"] .theme-switcher { padding: 3px; background: var(--ui-surface-soft); border: 1px solid var(--ui-border-soft); }
body[data-ui-version="20"] .theme-option { min-height: 28px; font-size: 11px; border-radius: 6px; }

body[data-ui-version="20"] .content {
  width: 100%;
  max-width: var(--v20-content);
  padding: 34px 34px 72px;
  margin: 0 auto;
}
body[data-ui-version="20"] .content--wide { max-width: 1560px; }
body[data-ui-version="20"] .top-notification-bell {
  position: fixed;
  top: 18px;
  right: 22px;
  z-index: 35;
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid var(--ui-border-soft);
  background: color-mix(in srgb, var(--ui-surface) 92%, transparent);
  box-shadow: none;
  backdrop-filter: blur(12px);
}
body[data-ui-version="20"] .bell-icon { color: var(--ui-accent-text); font-size: 9px; }

/* Page hierarchy */
body[data-ui-version="20"] .page-header {
  margin: 0 0 22px;
  padding: 0 116px 0 0;
  min-height: 54px;
  align-items: flex-start;
  gap: 18px;
}
body[data-ui-version="20"] .page-header > div:first-child { min-width: 0; max-width: 820px; }
body[data-ui-version="20"] .page-header p { max-width: 760px; margin: 8px 0 0; }
body[data-ui-version="20"] .page-header .eyebrow { margin: 0 0 6px; }
body[data-ui-version="20"] .breadcrumb { margin: 0 0 10px; font-size: 12px; }
body[data-ui-version="20"] .breadcrumb a { color: var(--ui-muted); text-decoration: none; }
body[data-ui-version="20"] .section-title,
body[data-ui-version="20"] .section-head h2 { color: var(--ui-text); font-size: 15px; font-weight: 760; letter-spacing: -.01em; }
body[data-ui-version="20"] .section-title.between,
body[data-ui-version="20"] .section-head { gap: 14px; }
body[data-ui-version="20"] .helper-line { margin-top: 5px; color: var(--ui-muted); font-size: 12px; }
body[data-ui-version="20"] .eyebrow { color: var(--ui-accent-text); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; }

/* Cards and surfaces */
body[data-ui-version="20"] .card {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border-soft);
  border-radius: var(--v20-radius);
  box-shadow: none;
  padding: 18px;
}
body[data-ui-version="20"] .card + .card,
body[data-ui-version="20"] .top-gap { margin-top: 16px !important; }
body[data-ui-version="20"] .space-bottom { margin-bottom: 16px !important; }
body[data-ui-version="20"] .subtle-card,
body[data-ui-version="20"] .estimate-clean-card,
body[data-ui-version="20"] .attention-item,
body[data-ui-version="20"] .report-card,
body[data-ui-version="20"] .notification-row,
body[data-ui-version="20"] .tender-check-card {
  background: var(--ui-surface-soft);
  border-color: var(--ui-border-soft);
  box-shadow: none;
}
body[data-ui-version="20"] .kpis { gap: 10px; margin-bottom: 16px; }
body[data-ui-version="20"] .kpi-card,
body[data-ui-version="20"] .card.kpi { min-height: 92px; padding: 15px 16px; }
body[data-ui-version="20"] .kpi-value { font-size: clamp(21px, 2vw, 28px); line-height: 1.1; margin-top: 7px; }
body[data-ui-version="20"] .attention-panel { padding: 16px; }
body[data-ui-version="20"] .attention-grid { gap: 8px; }
body[data-ui-version="20"] .attention-item { min-height: 74px; padding: 12px 14px; border-radius: 10px; }

/* Buttons */
body[data-ui-version="20"] .button,
body[data-ui-version="20"] button.button {
  min-height: 38px;
  padding: 8px 14px;
  border: 1px solid var(--ui-primary);
  border-radius: 9px;
  background: var(--ui-primary);
  color: var(--ui-primary-text);
  box-shadow: none;
  font-size: 13px;
  font-weight: 720;
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
}
body[data-ui-version="20"] .button:hover { filter: none; transform: none; }
body[data-ui-version="20"] .button:not(.secondary):not(.ghost):not(.danger):hover {
  background: var(--ui-primary-strong);
  border-color: var(--ui-primary-strong);
}
body[data-ui-version="20"] .button.small,
body[data-ui-version="20"] .small-button { min-height: 32px; padding: 6px 10px; font-size: 12px; }
body[data-ui-version="20"] .button.secondary {
  background: var(--ui-surface-raised);
  color: var(--ui-text);
  border-color: var(--ui-border);
}
body[data-ui-version="20"] .button.ghost {
  background: transparent;
  color: var(--ui-muted);
  border-color: transparent;
}
body[data-ui-version="20"] .button.ghost:hover { color: var(--ui-text); background: var(--ui-surface-soft); border-color: var(--ui-border-soft); }
body[data-ui-version="20"] .button.danger {
  background: transparent;
  color: var(--ui-danger);
  border-color: color-mix(in srgb, var(--ui-danger) 38%, transparent);
}
body[data-ui-version="20"] .button.danger:hover { background: color-mix(in srgb, var(--ui-danger) 10%, transparent); }
body[data-ui-version="20"] .button.disabled,
body[data-ui-version="20"] .button:disabled { opacity: .42; pointer-events: none; }
body[data-ui-version="20"] .actions,
body[data-ui-version="20"] .actions-inline,
body[data-ui-version="20"] .header-actions-wrap { gap: 8px; }
body[data-ui-version="20"] .actions-cell { gap: 4px; }

/* Forms */
body[data-ui-version="20"] label { color: var(--ui-muted); font-size: 12px; font-weight: 620; gap: 6px; }
body[data-ui-version="20"] input,
body[data-ui-version="20"] select,
body[data-ui-version="20"] textarea {
  min-height: 40px;
  padding: 9px 11px;
  border: 1px solid var(--ui-border);
  border-radius: 9px;
  background: var(--ui-surface-soft);
  color: var(--ui-text);
  box-shadow: none;
  font-size: 14px;
}
body[data-ui-version="20"] textarea { min-height: 84px; resize: vertical; }
body[data-ui-version="20"] input:hover,
body[data-ui-version="20"] select:hover,
body[data-ui-version="20"] textarea:hover { border-color: color-mix(in srgb, var(--ui-muted) 58%, var(--ui-border)); }
body[data-ui-version="20"] input:focus,
body[data-ui-version="20"] select:focus,
body[data-ui-version="20"] textarea:focus { border-color: var(--ui-primary); box-shadow: 0 0 0 3px var(--ui-focus); }
body[data-ui-version="20"] .form-grid { gap: 13px 14px; }
body[data-ui-version="20"] .filters-grid { gap: 10px; }
body[data-ui-version="20"] .compact-filters-card { padding: 10px 14px; }
body[data-ui-version="20"] .filters-disclosure > summary,
body[data-ui-version="20"] details.ui-disclosure > summary {
  min-height: 36px;
  padding: 6px 2px;
  cursor: pointer;
  color: var(--ui-text);
}
body[data-ui-version="20"] .filters-disclosure > summary::marker,
body[data-ui-version="20"] details.ui-disclosure > summary::marker { color: var(--ui-muted); }
body[data-ui-version="20"] .filters-actions { align-self: end; }
body[data-ui-version="20"] .form-save-bar {
  position: sticky;
  bottom: 12px;
  z-index: 8;
  display: flex;
  justify-content: flex-end;
  padding: 10px;
  margin: 16px -4px -4px;
  border: 1px solid var(--ui-border);
  border-radius: 11px;
  background: color-mix(in srgb, var(--ui-surface) 92%, transparent);
  backdrop-filter: blur(12px);
}
body[data-ui-version="20"] form.is-dirty .form-save-bar::before {
  content: "Есть несохранённые изменения";
  margin-right: auto;
  align-self: center;
  color: var(--ui-warning);
  font-size: 12px;
  font-weight: 650;
}

/* Tables and registries */
body[data-ui-version="20"] .table-scroll,
body[data-ui-version="20"] .table-wrap { border: 1px solid var(--ui-border-soft); border-radius: 10px; background: var(--ui-surface); }
body[data-ui-version="20"] .table { font-size: 13px; }
body[data-ui-version="20"] .table th {
  height: 38px;
  padding: 9px 12px;
  background: var(--ui-surface-soft);
  color: var(--ui-muted);
  border-bottom: 1px solid var(--ui-border-soft);
  font-size: 10px;
  font-weight: 760;
  letter-spacing: .055em;
  text-transform: uppercase;
  white-space: nowrap;
}
body[data-ui-version="20"] .table td { padding: 12px; border-bottom: 1px solid var(--ui-border-soft); vertical-align: middle; }
body[data-ui-version="20"] .table tbody tr:last-child td { border-bottom: 0; }
body[data-ui-version="20"] .table tbody tr:hover td { background: color-mix(in srgb, var(--ui-primary) 3.5%, var(--ui-surface)); }
body[data-ui-version="20"] .registry-primary { display: grid; gap: 3px; min-width: 190px; }
body[data-ui-version="20"] .registry-primary > a,
body[data-ui-version="20"] .registry-primary > strong { color: var(--ui-text); overflow-wrap: anywhere; }
body[data-ui-version="20"] .registry-meta { display: flex; flex-wrap: wrap; gap: 4px 8px; color: var(--ui-muted); font-size: 12px; }
body[data-ui-version="20"] .registry-money { display: grid; gap: 3px; min-width: 150px; }
body[data-ui-version="20"] .registry-money > div { display: flex; justify-content: space-between; gap: 14px; }
body[data-ui-version="20"] .registry-money span { color: var(--ui-muted); font-size: 11px; }
body[data-ui-version="20"] .registry-money strong { font-size: 12px; }
body[data-ui-version="20"] .registry-actions { text-align: right; white-space: nowrap; }
body[data-ui-version="20"] .action-menu { position: relative; display: inline-block; }
body[data-ui-version="20"] .action-menu > summary { list-style: none; cursor: pointer; }
body[data-ui-version="20"] .action-menu > summary::-webkit-details-marker { display: none; }
body[data-ui-version="20"] .action-menu-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 25;
  min-width: 190px;
  padding: 6px;
  border: 1px solid var(--ui-border);
  border-radius: 10px;
  background: var(--ui-surface-raised);
  box-shadow: 0 14px 38px rgba(0,0,0,.24);
}
body[data-ui-version="20"] .action-menu-panel a,
body[data-ui-version="20"] .action-menu-panel button:not(.button) {
  width: 100%;
  min-height: 34px;
  display: flex;
  align-items: center;
  padding: 7px 9px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--ui-text);
  text-align: left;
  text-decoration: none;
  font-size: 12px;
  cursor: pointer;
}
body[data-ui-version="20"] .action-menu-panel a:hover,
body[data-ui-version="20"] .action-menu-panel button:not(.button):hover { background: var(--ui-surface-soft); }
body[data-ui-version="20"] .action-menu-panel .danger-link { color: var(--ui-danger); }

/* Dialogs */
body[data-ui-version="20"] dialog.ui-dialog {
  width: min(760px, calc(100vw - 28px));
  max-height: min(88vh, 900px);
  padding: 0;
  border: 1px solid var(--ui-border);
  border-radius: 14px;
  background: var(--ui-surface);
  color: var(--ui-text);
  box-shadow: 0 28px 80px rgba(0,0,0,.38);
  overflow: hidden;
}
body[data-ui-version="20"] dialog.ui-dialog::backdrop { background: rgba(4,6,9,.68); backdrop-filter: blur(3px); }
body[data-ui-version="20"] .ui-dialog-head {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--ui-border-soft);
  background: var(--ui-surface);
}
body[data-ui-version="20"] .ui-dialog-head h2 { margin: 0 0 4px; }
body[data-ui-version="20"] .ui-dialog-close { width: 34px; min-width: 34px; height: 34px; border: 0; border-radius: 8px; background: var(--ui-surface-soft); color: var(--ui-muted); font-size: 22px; cursor: pointer; }
body[data-ui-version="20"] .ui-dialog-body { padding: 20px; overflow: auto; max-height: calc(88vh - 74px); }
body[data-ui-version="20"] .ui-dialog-wide { width: min(980px, calc(100vw - 28px)); }

/* Progressive disclosure and summaries */
body[data-ui-version="20"] .workflow-disclosure {
  border: 1px solid var(--ui-border-soft);
  border-radius: 10px;
  background: var(--ui-surface-soft);
  overflow: clip;
}
body[data-ui-version="20"] .workflow-disclosure + .workflow-disclosure { margin-top: 10px; }
body[data-ui-version="20"] .workflow-disclosure > summary {
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  cursor: pointer;
  color: var(--ui-text);
  font-weight: 720;
}
body[data-ui-version="20"] .workflow-disclosure > summary small { color: var(--ui-muted); font-weight: 500; }
body[data-ui-version="20"] .workflow-disclosure[open] > summary { border-bottom: 1px solid var(--ui-border-soft); }
body[data-ui-version="20"] .workflow-disclosure-body { padding: 14px; }
body[data-ui-version="20"] .metrics-more { margin: -6px 0 16px; }
body[data-ui-version="20"] .metrics-more > summary { width: fit-content; color: var(--ui-muted); cursor: pointer; font-size: 12px; }
body[data-ui-version="20"] .metrics-more-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 8px; margin-top: 10px; }
body[data-ui-version="20"] .metrics-more-grid > div { padding: 11px 12px; border: 1px solid var(--ui-border-soft); border-radius: 9px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .metrics-more-grid span { display: block; color: var(--ui-muted); font-size: 11px; }
body[data-ui-version="20"] .metrics-more-grid strong { display: block; margin-top: 3px; font-size: 15px; }

/* Project and estimate detail */
body[data-ui-version="20"] .anchor-nav,
body[data-ui-version="20"] .estimate-tabs,
body[data-ui-version="20"] .tender-tabs {
  position: sticky;
  top: 10px;
  z-index: 16;
  margin: 0 0 16px;
  padding: 5px;
  gap: 3px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 11px;
  background: color-mix(in srgb, var(--ui-surface) 92%, transparent);
  box-shadow: none;
  backdrop-filter: blur(12px);
  overflow-x: auto;
}
body[data-ui-version="20"] .anchor-nav a,
body[data-ui-version="20"] .estimate-tabs a,
body[data-ui-version="20"] .tender-tabs a { min-height: 32px; padding: 7px 10px; border-radius: 7px; color: var(--ui-muted); font-size: 12px; white-space: nowrap; }
body[data-ui-version="20"] .anchor-nav a:hover,
body[data-ui-version="20"] .estimate-tabs a:hover,
body[data-ui-version="20"] .estimate-tabs a.active,
body[data-ui-version="20"] .tender-tabs a:hover { color: var(--ui-text); background: var(--ui-surface-soft); }
body[data-ui-version="20"] .project-hero .actions-inline,
body[data-ui-version="20"] .estimate-doc-primary-actions,
body[data-ui-version="20"] .tender-header-actions { justify-content: flex-end; }
body[data-ui-version="20"] .estimate-doc-summary { padding: 16px; }
body[data-ui-version="20"] .estimate-doc-summary-main { gap: 8px; }
body[data-ui-version="20"] .estimate-doc-summary-main > div { padding: 12px; border: 0; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .finance-control-metrics { grid-template-columns: repeat(5,minmax(0,1fr)); gap: 7px; }
body[data-ui-version="20"] .finance-control-metrics > div { padding: 10px; border-radius: 8px; }
body[data-ui-version="20"] .project-task-row { padding: 10px 0; }

/* Tender registry */
body[data-ui-version="20"] .tender-kpis { grid-template-columns: repeat(4,minmax(0,1fr)); }
body[data-ui-version="20"] .tender-create-card { display: none; }
body[data-ui-version="20"] .tender-list { gap: 8px; }
body[data-ui-version="20"] .tender-row-card { border-color: var(--ui-border-soft); border-radius: 11px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .tender-row-open { padding: 13px 14px; }
body[data-ui-version="20"] .tender-row-finance { gap: 16px; }
body[data-ui-version="20"] .tender-row-side-actions { min-width: 136px; padding: 10px 12px 10px 0; }
body[data-ui-version="20"] .tender-summary-grid { gap: 10px; }
body[data-ui-version="20"] .tender-verdict-card { min-width: 0; }
body[data-ui-version="20"] .tender-edit-grid .workflow-disclosure { grid-column: 1 / -1; }

/* Empty states, badges and statuses */
body[data-ui-version="20"] .empty-state { min-height: 118px; padding: 22px; border: 1px dashed var(--ui-border); border-radius: 10px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .empty-state.compact,
body[data-ui-version="20"] .compact-empty { min-height: 74px; padding: 14px; }
body[data-ui-version="20"] .badge,
body[data-ui-version="20"] .score-pill,
body[data-ui-version="20"] .tender-state-badge,
body[data-ui-version="20"] .tender-free-badge,
body[data-ui-version="20"] .tender-assignee-badge { border-radius: 999px; font-size: 11px; font-weight: 720; }
body[data-ui-version="20"] .success-text { color: var(--ui-success) !important; }
body[data-ui-version="20"] .warning-text { color: var(--ui-warning) !important; }
body[data-ui-version="20"] .danger-text { color: var(--ui-danger) !important; }
body[data-ui-version="20"] .flash { border: 1px solid color-mix(in srgb, var(--ui-success) 35%, var(--ui-border)); background: color-mix(in srgb, var(--ui-success) 9%, var(--ui-surface)); box-shadow: none; }

/* Loading and submission feedback */
body[data-ui-version="20"] form.is-submitting .button[type="submit"],
body[data-ui-version="20"] form.is-submitting button:not([type="button"]) { opacity: .7; pointer-events: none; }
body[data-ui-version="20"] form.is-submitting .button[type="submit"]::after,
body[data-ui-version="20"] form.is-submitting button:not([type="button"])::after { content: "…"; margin-left: 5px; }

@media (max-width: 1180px) {
  body[data-ui-version="20"] .content { padding-left: 24px; padding-right: 24px; }
  body[data-ui-version="20"] .finance-control-metrics { grid-template-columns: repeat(3,minmax(0,1fr)); }
  body[data-ui-version="20"] .metrics-more-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  body[data-ui-version="20"] .tender-row-open { grid-template-columns: minmax(0,1.5fr) minmax(0,1fr); }
  body[data-ui-version="20"] .tender-row-finance { grid-column: 1 / -1; }
}

@media (max-width: 980px) {
  body[data-ui-version="20"] .layout { display: block; }
  body[data-ui-version="20"] .sidebar { width: min(88vw, 300px); padding-top: 64px; }
  body[data-ui-version="20"] .content { padding-top: 78px; }
  body[data-ui-version="20"] .top-notification-bell { display: none; }
  body[data-ui-version="20"] .page-header { padding-right: 0; }
  body[data-ui-version="20"] .nav-grouped { gap: 11px; }
  body[data-ui-version="20"] .nav-link { min-height: 42px; }
}

@media (max-width: 760px) {
  body[data-ui-version="20"] { font-size: 14px; }
  body[data-ui-version="20"] .content { padding: 70px 12px 52px; }
  body[data-ui-version="20"] .page-header { margin-bottom: 16px; gap: 12px; }
  body[data-ui-version="20"] .page-header p { display: none; }
  body[data-ui-version="20"] .page-header > .actions-inline,
  body[data-ui-version="20"] .page-header > .actions,
  body[data-ui-version="20"] .page-header > .header-actions-wrap,
  body[data-ui-version="20"] .page-header > .tender-header-actions,
  body[data-ui-version="20"] .page-header > .estimate-doc-primary-actions { flex-direction: row; flex-wrap: wrap; }
  body[data-ui-version="20"] .page-header > .actions-inline > *,
  body[data-ui-version="20"] .page-header > .actions > *,
  body[data-ui-version="20"] .page-header > .header-actions-wrap > *,
  body[data-ui-version="20"] .page-header > .tender-header-actions > *,
  body[data-ui-version="20"] .page-header > .estimate-doc-primary-actions > * { width: auto; flex: 0 1 auto; }
  body[data-ui-version="20"] .card { padding: 14px; border-radius: 10px; }
  body[data-ui-version="20"] .kpis,
  body[data-ui-version="20"] .kpis-six,
  body[data-ui-version="20"] .kpis-eight,
  body[data-ui-version="20"] .tender-kpis { grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
  body[data-ui-version="20"] .kpi-card,
  body[data-ui-version="20"] .card.kpi { min-height: 82px; padding: 12px; }
  body[data-ui-version="20"] .metrics-more-grid,
  body[data-ui-version="20"] .finance-control-metrics { grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .table-scroll { margin-left: -14px; margin-right: -14px; border-left: 0; border-right: 0; border-radius: 0; }
  body[data-ui-version="20"] .table th,
  body[data-ui-version="20"] .table td { padding: 10px; }
  body[data-ui-version="20"] .registry-money { min-width: 135px; }
  body[data-ui-version="20"] .action-menu-panel { position: fixed; left: 12px; right: 12px; top: auto; bottom: 12px; min-width: 0; }
  body[data-ui-version="20"] .ui-dialog-body { padding: 14px; }
  body[data-ui-version="20"] .ui-dialog-head { padding: 14px; }
  body[data-ui-version="20"] .tender-row-open { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .tender-row-finance { grid-column: auto; grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .tender-row-deadline { align-items: flex-start; }
  body[data-ui-version="20"] .tender-row-side-actions { width: 100%; padding: 0 12px 12px; }
}

@media (max-width: 460px) {
  body[data-ui-version="20"] .kpis,
  body[data-ui-version="20"] .kpis-six,
  body[data-ui-version="20"] .kpis-eight,
  body[data-ui-version="20"] .tender-kpis,
  body[data-ui-version="20"] .metrics-more-grid,
  body[data-ui-version="20"] .finance-control-metrics { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .button { white-space: normal; text-align: center; }
}

/* Focused workflows and cross-section refinements */
body[data-ui-version="20"] .focused-form-card { max-width: 980px; margin-inline: auto; }
body[data-ui-version="20"] .form-section-heading { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding-bottom: 10px; border-bottom: 1px solid var(--ui-border-soft); }
body[data-ui-version="20"] .form-section-heading strong { color: var(--ui-text); font-size: 15px; }
body[data-ui-version="20"] .compact-guidance-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; }
body[data-ui-version="20"] .compact-guidance-grid > div { display: grid; gap: 5px; padding: 12px; border: 1px solid var(--ui-border-soft); border-radius: 9px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .compact-form-panel { padding: 14px; border: 1px solid var(--ui-border-soft); border-radius: 10px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .settings-anchor-nav { top: 8px; }
body[data-ui-version="20"] .user-settings-disclosure > summary > span:first-child { display: grid; gap: 2px; }
body[data-ui-version="20"] .user-settings-disclosure.is-disabled { opacity: .68; }
body[data-ui-version="20"] .google-sheet-setting-row { padding: 10px 0; border-bottom: 1px solid var(--ui-border-soft); }
body[data-ui-version="20"] .google-sheet-setting-row:last-of-type { border-bottom: 0; }
body[data-ui-version="20"] .monthly-plan-item { padding: 11px 12px; border: 1px solid var(--ui-border-soft); border-radius: 9px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .action-menu-panel form { margin: 0; }
body[data-ui-version="20"] .action-menu-panel form + form { margin-top: 2px; }
body[data-ui-version="20"] .table-scroll:has(details.action-menu[open]) { overflow: visible; }
body[data-ui-version="20"] .company-expense-actions-disclosure > summary { cursor: pointer; color: var(--ui-muted); font-size: 12px; }
body[data-ui-version="20"] .company-expense-actions-disclosure[open] { min-width: 240px; }
body[data-ui-version="20"] .notification-row { padding: 14px; border-radius: 10px; }
body[data-ui-version="20"] .notification-row.unread { border-color: color-mix(in srgb, var(--ui-primary) 45%, var(--ui-border)); }
body[data-ui-version="20"] .notification-row-dot { background: var(--ui-muted); }
body[data-ui-version="20"] .notification-row.unread .notification-row-dot { background: var(--ui-primary); }
body[data-ui-version="20"] .login-card { width: min(440px, calc(100vw - 28px)); padding: 28px; border: 1px solid var(--ui-border); border-radius: 16px; background: var(--ui-surface); box-shadow: 0 22px 70px rgba(0,0,0,.32); }
body[data-ui-version="20"].login-page { background: radial-gradient(circle at 20% 0%, color-mix(in srgb, var(--ui-primary) 10%, transparent), transparent 34%), var(--ui-bg); }
body[data-ui-version="20"] .estimate-client-page { max-width: 1180px; }
body[data-ui-version="20"] .estimate-client-hero,
body[data-ui-version="20"] .estimate-client-table-card,
body[data-ui-version="20"] .estimate-final-approval { box-shadow: none; border-color: var(--ui-border-soft); }
body[data-ui-version="20"] .estimate-client-quick-decisions { gap: 7px; }
body[data-ui-version="20"] .estimate-client-review-toggle { min-width: 92px; }
body[data-ui-version="20"] .estimate-client-total { position: sticky; bottom: 10px; z-index: 6; border: 1px solid var(--ui-border); background: color-mix(in srgb, var(--ui-surface) 94%, transparent); backdrop-filter: blur(12px); }
body[data-ui-version="20"] .page-header .action-menu { flex: 0 0 auto; }
body[data-ui-version="20"] code { overflow-wrap: anywhere; }
body[data-ui-version="20"] .flash.error { border-color: color-mix(in srgb, var(--ui-danger) 35%, var(--ui-border)); background: color-mix(in srgb, var(--ui-danger) 9%, var(--ui-surface)); }

@media (max-width: 760px) {
  body[data-ui-version="20"] .compact-guidance-grid { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .form-section-heading { align-items: flex-start; flex-direction: column; gap: 3px; }
  body[data-ui-version="20"] .focused-form-card { margin-inline: 0; }
  body[data-ui-version="20"] .form-save-bar { bottom: 8px; flex-wrap: wrap; }
  body[data-ui-version="20"] form.is-dirty .form-save-bar::before { width: 100%; margin-bottom: 4px; }
  body[data-ui-version="20"] .estimate-client-total { bottom: 8px; }
  body[data-ui-version="20"] .notification-row-head { align-items: flex-start; gap: 6px; }
}


/* EVENT86 v20.0.2 — brand system */
body[data-ui-version="20"] ::selection {
  background: color-mix(in srgb, var(--ui-brand) 34%, transparent);
  color: var(--ui-text);
}
body[data-ui-version="20"] .brand-logo-pair {
  position: relative;
  display: inline-grid;
  align-items: center;
  flex: 0 0 auto;
  line-height: 0;
}
body[data-ui-version="20"] .brand-logo-pair > img {
  grid-area: 1 / 1;
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}
body[data-ui-version="20"] .brand-logo-on-light { display: none !important; }
body[data-ui-version="20"][data-theme="light"] .brand-logo-on-dark { display: none !important; }
body[data-ui-version="20"][data-theme="light"] .brand-logo-on-light { display: block !important; }

body[data-ui-version="20"] .brand-block {
  display: grid;
  justify-items: start;
  gap: 7px;
  text-decoration: none;
}
body[data-ui-version="20"] .brand-logo--sidebar { width: 184px; max-width: 100%; }
body[data-ui-version="20"] .brand-subtitle {
  margin-top: 0;
  color: var(--ui-muted);
  font-size: 9px;
  font-weight: 650;
  letter-spacing: .075em;
  text-transform: uppercase;
}
body[data-ui-version="20"] .brand-block:hover .brand-logo-pair { opacity: .9; }

body[data-ui-version="20"] .brand-logo--mobile { width: 122px; }
body[data-ui-version="20"] .mobile-topbar-brand {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  text-decoration: none;
}

body[data-ui-version="20"] .brand-logo--login {
  width: min(270px, 76vw);
  margin: 0 auto 18px;
}
body[data-ui-version="20"] .login-card {
  overflow: hidden;
}
body[data-ui-version="20"] .login-card::before {
  content: "";
  display: block;
  height: 4px;
  margin: -28px -28px 24px;
  background: var(--ui-brand);
}
body[data-ui-version="20"] .login-portal-label {
  margin-bottom: 8px;
  color: var(--ui-accent-text);
  font-size: 10px;
  font-weight: 780;
  letter-spacing: .13em;
  text-transform: uppercase;
  text-align: center;
}
body[data-ui-version="20"] .login-card h1,
body[data-ui-version="20"] .login-card > p {
  text-align: center;
}
body[data-ui-version="20"] .login-brand-footer {
  margin: 20px -28px -28px;
  padding: 14px 28px;
  border-top: 1px solid var(--ui-border-soft);
  color: var(--ui-muted);
  background: var(--ui-surface-soft);
  font-size: 10px;
  font-weight: 650;
  letter-spacing: .045em;
  text-align: center;
  text-transform: uppercase;
}

body[data-ui-version="20"] .estimate-client-brandline {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}
body[data-ui-version="20"] .brand-logo--client { width: 184px; }
body[data-ui-version="20"] .estimate-client-brandline > span:last-child {
  padding-left: 14px;
  border-left: 1px solid var(--ui-border);
  color: var(--ui-muted);
  font-size: 10px;
  font-weight: 760;
  letter-spacing: .105em;
  text-transform: uppercase;
}

body[data-ui-version="20"] .public-brand-footer {
  display: grid;
  grid-template-columns: 190px minmax(0,1fr);
  gap: 24px;
  align-items: center;
  width: min(1180px, 100%);
  margin: 28px auto 0;
  padding: 24px 0 8px;
  border-top: 1px solid var(--ui-border-soft);
}
body[data-ui-version="20"] .brand-logo--footer { width: 176px; }
body[data-ui-version="20"] .public-brand-footer-copy {
  display: grid;
  gap: 5px;
  min-width: 0;
  color: var(--ui-muted);
  font-size: 12px;
}
body[data-ui-version="20"] .public-brand-footer-copy strong {
  color: var(--ui-text);
  font-size: 13px;
}

body[data-ui-version="20"] .top-notification-bell.active,
body[data-ui-version="20"] .mobile-topbar-bell.active {
  border-color: color-mix(in srgb, var(--ui-brand) 36%, var(--ui-border));
  background: color-mix(in srgb, var(--ui-brand) 9%, var(--ui-surface));
}

@media (max-width: 760px) {
  body[data-ui-version="20"] .brand-logo--mobile { width: 112px; }
  body[data-ui-version="20"] .estimate-client-brandline {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }
  body[data-ui-version="20"] .estimate-client-brandline > span:last-child {
    padding-left: 0;
    border-left: 0;
  }
  body[data-ui-version="20"] .brand-logo--client { width: 164px; }
  body[data-ui-version="20"] .public-brand-footer {
    grid-template-columns: 1fr;
    gap: 14px;
    padding-top: 20px;
  }
  body[data-ui-version="20"] .brand-logo--footer { width: 154px; }
}

@media print {
  body[data-ui-version="20"] .brand-logo-on-dark { display: none !important; }
  body[data-ui-version="20"] .brand-logo-on-light { display: block !important; }
  body[data-ui-version="20"] .public-brand-footer { break-inside: avoid; }
}

/* EVENT86 v20.1 — task-first finance workspace */
body[data-ui-version="20"] .finance-subnav {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 4px 0 12px;
  margin: -2px 0 12px;
  scrollbar-width: thin;
}
body[data-ui-version="20"] .finance-subnav-link {
  flex: 0 0 auto;
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  padding: 7px 11px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 999px;
  background: var(--ui-surface-soft);
  color: var(--ui-muted);
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
}
body[data-ui-version="20"] .finance-subnav-link:hover { color: var(--ui-text); border-color: var(--ui-border); }
body[data-ui-version="20"] .finance-subnav-link.is-active {
  color: var(--ui-primary-text);
  background: var(--ui-brand);
  border-color: var(--ui-brand);
}
body[data-ui-version="20"] .finance-page-header { margin-bottom: 14px; }
body[data-ui-version="20"] .finance-page-header .eyebrow { color: var(--ui-accent-text); }

body[data-ui-version="20"] .finance-summary-grid {
  display: grid;
  gap: 10px;
  margin: 0 0 14px;
}
body[data-ui-version="20"] .finance-summary-grid--three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
body[data-ui-version="20"] .finance-summary-grid--four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
body[data-ui-version="20"] .finance-summary-grid--five { grid-template-columns: repeat(5, minmax(0, 1fr)); }
body[data-ui-version="20"] .finance-summary-card {
  min-width: 0;
  display: grid;
  gap: 4px;
  padding: 14px 15px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 11px;
  background: var(--ui-surface);
  color: var(--ui-text);
  text-decoration: none;
  box-shadow: none;
}
body[data-ui-version="20"] .finance-summary-card:hover { border-color: var(--ui-border); transform: translateY(-1px); }
body[data-ui-version="20"] .finance-summary-card > span { color: var(--ui-muted); font-size: 12px; font-weight: 700; }
body[data-ui-version="20"] .finance-summary-card > strong { min-width: 0; overflow-wrap: anywhere; font-size: clamp(19px, 2vw, 27px); line-height: 1.08; }
body[data-ui-version="20"] .finance-summary-card > small { color: var(--ui-muted); line-height: 1.3; }
body[data-ui-version="20"] .finance-summary-card.is-attention { border-color: color-mix(in srgb, var(--ui-warning) 40%, var(--ui-border)); background: color-mix(in srgb, var(--ui-warning) 5%, var(--ui-surface)); }
body[data-ui-version="20"] .finance-summary-card.is-danger { border-color: color-mix(in srgb, var(--ui-danger) 38%, var(--ui-border)); background: color-mix(in srgb, var(--ui-danger) 5%, var(--ui-surface)); }
body[data-ui-version="20"] .finance-summary-card.is-success { border-color: color-mix(in srgb, var(--ui-success) 35%, var(--ui-border)); background: color-mix(in srgb, var(--ui-success) 5%, var(--ui-surface)); }

body[data-ui-version="20"] .finance-work-section,
body[data-ui-version="20"] .finance-history-section,
body[data-ui-version="20"] .finance-insights-card,
body[data-ui-version="20"] .finance-filter-card { margin-bottom: 12px; }
body[data-ui-version="20"] .finance-task-list { display: grid; gap: 9px; margin-top: 12px; }
body[data-ui-version="20"] .finance-task-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
  gap: 16px;
  padding: 15px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 11px;
  background: var(--ui-surface-soft);
}
body[data-ui-version="20"] .finance-task-card:hover { border-color: var(--ui-border); }
body[data-ui-version="20"] .finance-task-main,
body[data-ui-version="20"] .finance-task-actions { min-width: 0; }
body[data-ui-version="20"] .finance-task-title-row,
body[data-ui-version="20"] .debt-card-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}
body[data-ui-version="20"] .finance-task-title-row h2,
body[data-ui-version="20"] .debt-card-title-row h2 { margin: 2px 0 0; font-size: 16px; overflow-wrap: anywhere; }
body[data-ui-version="20"] .finance-task-kicker { color: var(--ui-muted); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
body[data-ui-version="20"] .finance-task-amount,
body[data-ui-version="20"] .debt-card-amount { flex: 0 0 auto; font-size: 18px; white-space: nowrap; }
body[data-ui-version="20"] .finance-task-project { display: inline-block; margin-top: 7px; font-weight: 700; overflow-wrap: anywhere; }
body[data-ui-version="20"] .finance-task-meta,
body[data-ui-version="20"] .debt-card-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}
body[data-ui-version="20"] .finance-task-meta > span,
body[data-ui-version="20"] .debt-card-meta > span {
  min-width: 0;
  display: grid;
  gap: 2px;
  color: var(--ui-text);
  overflow-wrap: anywhere;
}
body[data-ui-version="20"] .finance-task-meta small,
body[data-ui-version="20"] .debt-card-meta small { color: var(--ui-muted); font-size: 10px; text-transform: uppercase; letter-spacing: .05em; }
body[data-ui-version="20"] .finance-task-actions { display: grid; align-content: start; gap: 8px; }
body[data-ui-version="20"] .finance-task-actions--single { align-content: center; }
body[data-ui-version="20"] .finance-primary-action,
body[data-ui-version="20"] .finance-upload-action { display: grid; gap: 8px; }
body[data-ui-version="20"] .finance-primary-action label,
body[data-ui-version="20"] .finance-upload-action label { display: grid; gap: 4px; font-size: 11px; color: var(--ui-muted); }
body[data-ui-version="20"] .finance-danger-disclosure { border-color: color-mix(in srgb, var(--ui-danger) 26%, var(--ui-border-soft)); }
body[data-ui-version="20"] .finance-danger-disclosure > summary { color: var(--ui-danger); }
body[data-ui-version="20"] .nested-disclosure { background: transparent; }
body[data-ui-version="20"] .inline-notice.neutral {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 9px;
  color: var(--ui-muted);
}
body[data-ui-version="20"] .inline-notice.neutral strong { color: var(--ui-text); }
body[data-ui-version="20"] .finance-compact-list { display: grid; gap: 6px; }
body[data-ui-version="20"] .finance-compact-row {
  display: grid;
  grid-template-columns: minmax(0,1.4fr) minmax(180px,.8fr) auto;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 9px;
  color: var(--ui-text);
  text-decoration: none;
}
body[data-ui-version="20"] .finance-compact-row:hover { background: var(--ui-surface-soft); border-color: var(--ui-border); }
body[data-ui-version="20"] .finance-compact-row > div { min-width: 0; display: grid; gap: 2px; }
body[data-ui-version="20"] .finance-compact-row span:not(.badge) { color: var(--ui-muted); font-size: 12px; overflow-wrap: anywhere; }

body[data-ui-version="20"] .finance-list-toolbar,
body[data-ui-version="20"] .finance-view-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 12px;
}
body[data-ui-version="20"] .debt-card-list { display: grid; gap: 8px; margin-top: 12px; }
body[data-ui-version="20"] .debt-card {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 14px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 10px;
  background: var(--ui-surface-soft);
}
body[data-ui-version="20"] .debt-card.is-overdue { border-color: color-mix(in srgb, var(--ui-danger) 38%, var(--ui-border)); background: color-mix(in srgb, var(--ui-danger) 5%, var(--ui-surface-soft)); }
body[data-ui-version="20"] .debt-card[hidden] { display: none !important; }
body[data-ui-version="20"] .debt-card-progress { display: flex; align-items: center; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }
body[data-ui-version="20"] .debt-card-progress > div { min-width: 92px; display: grid; gap: 2px; text-align: right; }
body[data-ui-version="20"] .debt-card-progress > div span { color: var(--ui-muted); font-size: 11px; }
body[data-ui-version="20"] .debt-card-progress > div strong { font-size: 14px; }

body[data-ui-version="20"] .finance-period-control {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 10px;
  background: var(--ui-surface);
}
body[data-ui-version="20"] .finance-period-control > div { min-width: 190px; display: grid; text-align: center; }
body[data-ui-version="20"] .finance-period-control small { color: var(--ui-muted); font-size: 10px; text-transform: uppercase; letter-spacing: .05em; }
body[data-ui-version="20"] .finance-mini-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
body[data-ui-version="20"] .finance-mini-metrics > div { display: grid; gap: 3px; padding: 10px; border: 1px solid var(--ui-border-soft); border-radius: 9px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .finance-mini-metrics span { color: var(--ui-muted); font-size: 11px; }
body[data-ui-version="20"] .finance-mini-metrics strong { font-size: 15px; overflow-wrap: anywhere; }
body[data-ui-version="20"] .cashflow-create-dialog { width: min(980px, calc(100vw - 28px)); }
body[data-ui-version="20"] .cashflow-create-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 0 18px 18px; }
body[data-ui-version="20"] .cashflow-create-grid .mini-form-card { margin: 0; }
body[data-ui-version="20"] .cashflow-create-grid h3 { margin: 8px 0 0; }

body[data-ui-version="20"] .integration-inline-status {
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  margin-bottom: 12px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 10px;
  background: var(--ui-surface-soft);
}
body[data-ui-version="20"] .integration-inline-status > div { display: grid; gap: 1px; }
body[data-ui-version="20"] .integration-inline-status > div span { color: var(--ui-muted); font-size: 12px; }
body[data-ui-version="20"] .integration-status-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--ui-muted); box-shadow: 0 0 0 4px color-mix(in srgb, var(--ui-muted) 12%, transparent); }
body[data-ui-version="20"] .integration-inline-status.is-ready .integration-status-dot,
body[data-ui-version="20"] .state-ready .integration-status-dot { background: var(--ui-success); box-shadow: 0 0 0 4px color-mix(in srgb, var(--ui-success) 14%, transparent); }
body[data-ui-version="20"] .integration-inline-status.is-off .integration-status-dot,
body[data-ui-version="20"] .state-off .integration-status-dot { background: var(--ui-muted); }
body[data-ui-version="20"] .state-partial .integration-status-dot { background: var(--ui-warning); box-shadow: 0 0 0 4px color-mix(in srgb, var(--ui-warning) 14%, transparent); }

body[data-ui-version="20"] .bank-account-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 9px; margin-top: 12px; }
body[data-ui-version="20"] .bank-account-card { display: grid; gap: 12px; padding: 14px; border: 1px solid var(--ui-border-soft); border-radius: 10px; background: var(--ui-surface-soft); color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .bank-account-card:hover,
body[data-ui-version="20"] .bank-account-card.is-selected { border-color: color-mix(in srgb, var(--ui-brand) 42%, var(--ui-border)); background: color-mix(in srgb, var(--ui-brand) 5%, var(--ui-surface-soft)); }
body[data-ui-version="20"] .bank-account-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
body[data-ui-version="20"] .bank-account-card-head > div { min-width: 0; display: grid; gap: 2px; }
body[data-ui-version="20"] .bank-account-card-head span { color: var(--ui-muted); font-size: 11px; overflow-wrap: anywhere; }
body[data-ui-version="20"] .bank-account-card-balance { display: grid; gap: 2px; }
body[data-ui-version="20"] .bank-account-card-balance span { color: var(--ui-muted); font-size: 11px; }
body[data-ui-version="20"] .bank-account-card-balance strong { font-size: 22px; overflow-wrap: anywhere; }
body[data-ui-version="20"] .bank-account-card-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 10px; font-size: 11px; color: var(--ui-muted); }
body[data-ui-version="20"] .bank-account-card-meta span:last-child { grid-column: 1 / -1; }
body[data-ui-version="20"] .bank-account-card-meta strong { color: var(--ui-text); font-weight: 650; }
body[data-ui-version="20"] .bank-status-switcher { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 8px; margin-bottom: 12px; }
body[data-ui-version="20"] .bank-status-chip { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 10px 12px; border: 1px solid var(--ui-border-soft); border-radius: 9px; background: var(--ui-surface); color: var(--ui-muted); text-decoration: none; font-size: 12px; font-weight: 700; }
body[data-ui-version="20"] .bank-status-chip strong { color: var(--ui-text); font-size: 17px; }
body[data-ui-version="20"] .bank-status-chip.is-active { border-color: color-mix(in srgb, var(--ui-brand) 42%, var(--ui-border)); background: var(--ui-brand-soft); color: var(--ui-text); }

body[data-ui-version="20"] .integration-overview { margin-bottom: 12px; padding: 16px; border: 1px solid var(--ui-border-soft); border-radius: 12px; background: var(--ui-surface); }
body[data-ui-version="20"] .integration-overview-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
body[data-ui-version="20"] .integration-overview-head h2 { margin: 2px 0 0; }
body[data-ui-version="20"] .integration-overview-count { display: flex; align-items: baseline; gap: 5px; color: var(--ui-muted); }
body[data-ui-version="20"] .integration-overview-count strong { color: var(--ui-text); font-size: 24px; }
body[data-ui-version="20"] .integration-status-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 8px; }
body[data-ui-version="20"] .integration-status-card { min-width: 0; display: grid; gap: 7px; padding: 12px; border: 1px solid var(--ui-border-soft); border-radius: 9px; background: var(--ui-surface-soft); color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .integration-status-card:hover { border-color: var(--ui-border); }
body[data-ui-version="20"] .integration-status-card.state-ready { border-color: color-mix(in srgb, var(--ui-success) 30%, var(--ui-border)); }
body[data-ui-version="20"] .integration-status-card.state-partial { border-color: color-mix(in srgb, var(--ui-warning) 32%, var(--ui-border)); }
body[data-ui-version="20"] .integration-status-card-head { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 8px; }
body[data-ui-version="20"] .integration-status-badge { color: var(--ui-muted); font-size: 10px; font-weight: 700; }
body[data-ui-version="20"] .integration-status-card p { margin: 0; color: var(--ui-muted); font-size: 12px; line-height: 1.35; }
body[data-ui-version="20"] .integration-status-card small { color: var(--ui-muted); font-size: 10px; }

@media (max-width: 1180px) {
  body[data-ui-version="20"] .finance-summary-grid--five { grid-template-columns: repeat(3, minmax(0,1fr)); }
  body[data-ui-version="20"] .finance-summary-grid--four { grid-template-columns: repeat(2, minmax(0,1fr)); }
  body[data-ui-version="20"] .integration-status-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  body[data-ui-version="20"] .bank-account-card-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  body[data-ui-version="20"] .finance-task-meta,
  body[data-ui-version="20"] .debt-card-meta { grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 860px) {
  body[data-ui-version="20"] .finance-task-card { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .finance-summary-grid--three,
  body[data-ui-version="20"] .finance-summary-grid--five { grid-template-columns: repeat(2, minmax(0,1fr)); }
  body[data-ui-version="20"] .finance-mini-metrics { grid-template-columns: repeat(2, minmax(0,1fr)); }
  body[data-ui-version="20"] .finance-view-toolbar { align-items: stretch; flex-direction: column; }
  body[data-ui-version="20"] .finance-period-control { justify-content: center; }
  body[data-ui-version="20"] .bank-status-switcher { grid-template-columns: repeat(2, minmax(0,1fr)); }
  body[data-ui-version="20"] .finance-compact-row { grid-template-columns: 1fr auto; }
  body[data-ui-version="20"] .finance-compact-row > div:nth-child(2) { grid-column: 1; }
}

@media (max-width: 680px) {
  body[data-ui-version="20"] .finance-subnav { margin-left: -2px; margin-right: -2px; padding-bottom: 10px; }
  body[data-ui-version="20"] .finance-page-header { align-items: stretch; }
  body[data-ui-version="20"] .finance-page-header > form,
  body[data-ui-version="20"] .finance-page-header > .button,
  body[data-ui-version="20"] .finance-page-header > details { width: 100%; }
  body[data-ui-version="20"] .finance-summary-grid--three,
  body[data-ui-version="20"] .finance-summary-grid--four,
  body[data-ui-version="20"] .finance-summary-grid--five { grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .finance-summary-card { padding: 12px; }
  body[data-ui-version="20"] .finance-summary-card > strong { font-size: 19px; }
  body[data-ui-version="20"] .finance-list-toolbar { align-items: stretch; flex-direction: column; }
  body[data-ui-version="20"] .finance-task-title-row,
  body[data-ui-version="20"] .debt-card-title-row { flex-direction: column; gap: 6px; }
  body[data-ui-version="20"] .finance-task-amount,
  body[data-ui-version="20"] .debt-card-amount { white-space: normal; }
  body[data-ui-version="20"] .finance-task-meta,
  body[data-ui-version="20"] .debt-card-meta { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .debt-card { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .debt-card-progress { justify-content: flex-start; }
  body[data-ui-version="20"] .debt-card-progress > div { text-align: left; }
  body[data-ui-version="20"] .finance-period-control { display: grid; grid-template-columns: auto 1fr auto; }
  body[data-ui-version="20"] .finance-period-control > div { min-width: 0; }
  body[data-ui-version="20"] .finance-period-control .button { grid-column: 1 / -1; }
  body[data-ui-version="20"] .cashflow-create-grid { grid-template-columns: 1fr; padding: 0 12px 12px; }
  body[data-ui-version="20"] .bank-account-card-grid,
  body[data-ui-version="20"] .integration-status-grid { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .integration-inline-status { grid-template-columns: auto 1fr; }
  body[data-ui-version="20"] .integration-inline-status .button { grid-column: 1 / -1; }
  body[data-ui-version="20"] .bank-status-switcher { grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .integration-overview-head { align-items: flex-start; }

  body[data-ui-version="20"] .finance-history-table thead,
  body[data-ui-version="20"] .reports-month-table thead,
  body[data-ui-version="20"] .reports-table-card:last-child table thead,
  body[data-ui-version="20"] .bank-operations-table thead,
  body[data-ui-version="20"] .bank-reconciliation-table thead { display: none; }
  body[data-ui-version="20"] .finance-history-table,
  body[data-ui-version="20"] .finance-history-table tbody,
  body[data-ui-version="20"] .finance-history-table tr,
  body[data-ui-version="20"] .finance-history-table td,
  body[data-ui-version="20"] .reports-month-table,
  body[data-ui-version="20"] .reports-month-table tbody,
  body[data-ui-version="20"] .reports-month-table tr,
  body[data-ui-version="20"] .reports-month-table td,
  body[data-ui-version="20"] .bank-operations-table,
  body[data-ui-version="20"] .bank-operations-table tbody,
  body[data-ui-version="20"] .bank-operations-table tr,
  body[data-ui-version="20"] .bank-operations-table td,
  body[data-ui-version="20"] .bank-reconciliation-table,
  body[data-ui-version="20"] .bank-reconciliation-table tbody,
  body[data-ui-version="20"] .bank-reconciliation-table tr,
  body[data-ui-version="20"] .bank-reconciliation-table td { display: block; width: 100%; }
  body[data-ui-version="20"] .finance-history-table tr,
  body[data-ui-version="20"] .reports-month-table tr,
  body[data-ui-version="20"] .bank-operations-table tr,
  body[data-ui-version="20"] .bank-reconciliation-table tr { margin-bottom: 9px; padding: 10px; border: 1px solid var(--ui-border-soft); border-radius: 10px; background: var(--ui-surface-soft); }
  body[data-ui-version="20"] .finance-history-table td,
  body[data-ui-version="20"] .reports-month-table td,
  body[data-ui-version="20"] .bank-operations-table td,
  body[data-ui-version="20"] .bank-reconciliation-table td { position: relative; min-height: 30px; padding: 6px 0 6px 42% !important; border: 0 !important; text-align: left !important; overflow: visible; }
  body[data-ui-version="20"] .finance-history-table td::before,
  body[data-ui-version="20"] .reports-month-table td::before,
  body[data-ui-version="20"] .bank-operations-table td::before,
  body[data-ui-version="20"] .bank-reconciliation-table td::before { content: attr(data-label); position: absolute; left: 0; top: 6px; width: 38%; color: var(--ui-muted); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
  body[data-ui-version="20"] .bank-link-details,
  body[data-ui-version="20"] .bank-reconcile-details { width: 100%; }
  body[data-ui-version="20"] .bank-link-form,
  body[data-ui-version="20"] .bank-rec-link-panel { position: static !important; width: 100% !important; max-width: none !important; margin-top: 8px; }
}

@media (max-width: 430px) {
  body[data-ui-version="20"] .finance-summary-grid--three,
  body[data-ui-version="20"] .finance-summary-grid--four,
  body[data-ui-version="20"] .finance-summary-grid--five { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .finance-mini-metrics { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .bank-status-switcher { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .finance-compact-row { grid-template-columns: 1fr; }
}

/* EVENT86 v20.2 — role dashboard, action center and global search */
body[data-ui-version="20"] .app-toolbar {
  min-height: 46px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  margin: -2px 0 18px;
}
body[data-ui-version="20"] .global-search-trigger,
body[data-ui-version="20"] .toolbar-action-link {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 10px;
  background: var(--ui-surface);
  color: var(--ui-muted);
  padding: 7px 10px;
  font: inherit;
  font-size: 12px;
  font-weight: 650;
  text-decoration: none;
}
body[data-ui-version="20"] .global-search-trigger { min-width: 230px; justify-content: flex-start; cursor: pointer; }
body[data-ui-version="20"] .global-search-trigger:hover,
body[data-ui-version="20"] .toolbar-action-link:hover,
body[data-ui-version="20"] .toolbar-action-link.active { color: var(--ui-text); border-color: color-mix(in srgb, var(--ui-brand) 24%, var(--ui-border)); background: var(--ui-surface-raised); }
body[data-ui-version="20"] .global-search-trigger svg,
body[data-ui-version="20"] .mobile-topbar-search svg { width: 17px; height: 17px; fill: currentColor; flex: 0 0 auto; }
body[data-ui-version="20"] .global-search-trigger kbd { margin-left: auto; }
body[data-ui-version="20"] kbd { border: 1px solid var(--ui-border); background: var(--ui-surface-soft); border-radius: 5px; color: var(--ui-muted); padding: 1px 5px; font: inherit; font-size: 10px; }
body[data-ui-version="20"] .toolbar-count,
body[data-ui-version="20"] .nav-count {
  min-width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--ui-brand);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  padding: 0 5px;
}
body[data-ui-version="20"] .nav-count { margin-left: auto; }
body[data-ui-version="20"] .mobile-topbar-search {
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--ui-text);
}

body.global-search-open { overflow: hidden; }
body[data-ui-version="20"] .global-search-modal[hidden] { display: none; }
body[data-ui-version="20"] .global-search-modal { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: start center; padding: min(11vh, 96px) 18px 24px; }
body[data-ui-version="20"] .global-search-backdrop { position: absolute; inset: 0; background: rgba(5,7,10,.72); backdrop-filter: blur(5px); }
body[data-ui-version="20"] .global-search-dialog {
  position: relative;
  width: min(760px, 100%);
  max-height: min(720px, 80vh);
  display: grid;
  grid-template-rows: auto auto minmax(120px,1fr) auto;
  overflow: hidden;
  border: 1px solid var(--ui-border);
  border-radius: 16px;
  background: var(--ui-surface-raised);
  box-shadow: 0 24px 80px rgba(0,0,0,.38);
}
body[data-ui-version="20"] .global-search-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 18px 20px 12px; }
body[data-ui-version="20"] .global-search-head > div { display: grid; gap: 2px; }
body[data-ui-version="20"] .global-search-head strong { font-size: 17px; }
body[data-ui-version="20"] .global-search-head span { color: var(--ui-muted); font-size: 12px; }
body[data-ui-version="20"] .global-search-form { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 10px; margin: 0 20px 12px; padding: 0 13px; border: 1px solid var(--ui-border); border-radius: 11px; background: var(--ui-surface-soft); }
body[data-ui-version="20"] .global-search-form:focus-within { border-color: var(--ui-brand); box-shadow: 0 0 0 3px var(--ui-focus); }
body[data-ui-version="20"] .global-search-form svg { width: 19px; height: 19px; fill: var(--ui-muted); }
body[data-ui-version="20"] .global-search-form input { min-width: 0; height: 48px; border: 0 !important; outline: 0 !important; box-shadow: none !important; padding: 0; background: transparent; color: var(--ui-text); font-size: 15px; }
body[data-ui-version="20"] .global-search-results { min-height: 170px; overflow-y: auto; padding: 0 10px 10px; }
body[data-ui-version="20"] .global-search-placeholder { min-height: 160px; display: grid; place-content: center; gap: 5px; text-align: center; color: var(--ui-muted); }
body[data-ui-version="20"] .global-search-placeholder strong { color: var(--ui-text); }
body[data-ui-version="20"] .global-search-group { padding: 7px 0; }
body[data-ui-version="20"] .global-search-group + .global-search-group { border-top: 1px solid var(--ui-border-soft); }
body[data-ui-version="20"] .global-search-group-title { padding: 4px 10px 6px; color: var(--ui-muted); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
body[data-ui-version="20"] .global-search-result { display: grid; grid-template-columns: 84px minmax(0,1fr) auto; align-items: center; gap: 12px; min-height: 58px; padding: 9px 10px; border-radius: 10px; color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .global-search-result:hover,
body[data-ui-version="20"] .global-search-result.is-active { background: var(--ui-brand-soft); }
body[data-ui-version="20"] .global-search-result-kind { color: var(--ui-muted); font-size: 10px; text-transform: uppercase; letter-spacing: .04em; }
body[data-ui-version="20"] .global-search-result-copy { min-width: 0; display: grid; gap: 2px; }
body[data-ui-version="20"] .global-search-result-copy strong,
body[data-ui-version="20"] .global-search-result-copy small { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
body[data-ui-version="20"] .global-search-result-copy small,
body[data-ui-version="20"] .global-search-result-side small { color: var(--ui-muted); font-size: 11px; }
body[data-ui-version="20"] .global-search-result-side { display: grid; justify-items: end; gap: 3px; }
body[data-ui-version="20"] .global-search-footer { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 10px 20px; border-top: 1px solid var(--ui-border-soft); color: var(--ui-muted); font-size: 11px; }

body[data-ui-version="20"] .dashboard-hero {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: stretch;
  gap: 18px;
  margin-bottom: 18px;
  padding: 24px;
  border: 1px solid color-mix(in srgb, var(--ui-brand) 20%, var(--ui-border));
  border-radius: 16px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--ui-brand) 10%, var(--ui-surface)) 0%, var(--ui-surface) 55%);
}
body[data-ui-version="20"] .dashboard-hero-copy { max-width: 780px; }
body[data-ui-version="20"] .dashboard-hero-copy p { max-width: 680px; margin: 9px 0 0; color: var(--ui-muted); font-size: 14px; }
body[data-ui-version="20"] .dashboard-hero-actions { margin-top: 18px; }
body[data-ui-version="20"] .dashboard-action-total { min-width: 190px; display: flex; align-items: center; gap: 12px; padding: 18px; border: 1px solid var(--ui-border-soft); border-radius: 13px; background: var(--ui-surface-soft); color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .dashboard-action-total:hover { border-color: var(--ui-brand); }
body[data-ui-version="20"] .dashboard-action-number { font-size: 36px; line-height: 1; font-weight: 850; color: var(--ui-accent-text); }
body[data-ui-version="20"] .dashboard-action-total > span:last-child { display: grid; gap: 2px; }
body[data-ui-version="20"] .dashboard-action-total small { color: var(--ui-muted); }
body[data-ui-version="20"] .dashboard-role-kpis { grid-template-columns: repeat(auto-fit,minmax(175px,1fr)); }
body[data-ui-version="20"] .dashboard-main-grid { grid-template-columns: minmax(320px,.9fr) minmax(520px,1.4fr); }
body[data-ui-version="20"] .dashboard-actions-list { display: grid; gap: 5px; }
body[data-ui-version="20"] .dashboard-action-row { display: grid; grid-template-columns: auto minmax(0,1fr) auto; align-items: center; gap: 10px; min-height: 58px; padding: 9px 8px; border-radius: 9px; color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .dashboard-action-row:hover { background: var(--ui-surface-soft); }
body[data-ui-version="20"] .dashboard-action-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--ui-muted); }
body[data-ui-version="20"] .dashboard-action-row.danger .dashboard-action-dot { background: var(--ui-danger); box-shadow: 0 0 0 4px color-mix(in srgb,var(--ui-danger) 14%,transparent); }
body[data-ui-version="20"] .dashboard-action-row.warning .dashboard-action-dot { background: var(--ui-warning); }
body[data-ui-version="20"] .dashboard-action-row.info .dashboard-action-dot { background: #6ea8fe; }
body[data-ui-version="20"] .dashboard-action-copy { min-width: 0; display: grid; gap: 2px; }
body[data-ui-version="20"] .dashboard-action-copy strong,
body[data-ui-version="20"] .dashboard-action-copy small { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
body[data-ui-version="20"] .dashboard-action-copy small { color: var(--ui-muted); }
body[data-ui-version="20"] .dashboard-action-amount { white-space: nowrap; font-weight: 750; }
body[data-ui-version="20"] .calendar-dashboard-layout { display: grid; grid-template-columns: 190px minmax(0,1fr); gap: 18px; align-items: start; }
body[data-ui-version="20"] .calendar-dashboard-summary { display: grid; gap: 6px; padding: 14px; border-radius: 11px; background: var(--ui-surface-soft); color: var(--ui-muted); }
body[data-ui-version="20"] .calendar-dashboard-summary strong { color: var(--ui-text); font-size: 16px; }

body[data-ui-version="20"] .action-summary-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 10px; margin-bottom: 14px; }
body[data-ui-version="20"] .action-summary-card { display: flex; align-items: center; gap: 12px; min-height: 92px; padding: 15px; border: 1px solid var(--ui-border-soft); border-radius: 12px; background: var(--ui-surface); color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .action-summary-card:hover { border-color: var(--ui-border); background: var(--ui-surface-raised); }
body[data-ui-version="20"] .action-summary-value { min-width: 48px; font-size: 30px; line-height: 1; font-weight: 850; }
body[data-ui-version="20"] .action-summary-card > span:last-child { display: grid; gap: 2px; }
body[data-ui-version="20"] .action-summary-card small { color: var(--ui-muted); }
body[data-ui-version="20"] .action-summary-card.danger .action-summary-value { color: var(--ui-danger); }
body[data-ui-version="20"] .action-summary-card.warning .action-summary-value { color: var(--ui-warning); }
body[data-ui-version="20"] .action-summary-card.info .action-summary-value { color: #6ea8fe; }
body[data-ui-version="20"] .action-center-filters { display: grid; grid-template-columns: minmax(240px,1fr) minmax(160px,.45fr) minmax(160px,.45fr) auto auto; align-items: end; gap: 10px; margin-bottom: 14px; }
body[data-ui-version="20"] .action-center-list { display: grid; gap: 8px; }
body[data-ui-version="20"] .action-center-item { position: relative; display: grid; grid-template-columns: auto minmax(0,1fr) auto; align-items: center; gap: 14px; min-height: 112px; padding: 16px; border: 1px solid var(--ui-border-soft); border-radius: 12px; background: var(--ui-surface); }
body[data-ui-version="20"] .action-center-item:hover { border-color: var(--ui-border); }
body[data-ui-version="20"] .action-center-item.snoozed { opacity: .66; }
body[data-ui-version="20"] .action-center-marker { width: 5px; align-self: stretch; border-radius: 999px; background: var(--ui-muted); }
body[data-ui-version="20"] .action-center-item.danger .action-center-marker { background: var(--ui-danger); }
body[data-ui-version="20"] .action-center-item.warning .action-center-marker { background: var(--ui-warning); }
body[data-ui-version="20"] .action-center-item.info .action-center-marker { background: #6ea8fe; }
body[data-ui-version="20"] .action-center-main { min-width: 0; }
body[data-ui-version="20"] .action-center-topline { display: flex; flex-wrap: wrap; align-items: center; gap: 7px; margin-bottom: 5px; }
body[data-ui-version="20"] .action-category-badge { background: var(--ui-surface-soft); color: var(--ui-muted); }
body[data-ui-version="20"] .action-due { color: var(--ui-muted); font-size: 11px; font-weight: 700; }
body[data-ui-version="20"] .action-due.overdue { color: var(--ui-danger); }
body[data-ui-version="20"] .action-center-main h2 { margin: 0; font-size: 16px; }
body[data-ui-version="20"] .action-center-main h2 a { color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .action-center-main p { margin: 4px 0 0; }
body[data-ui-version="20"] .action-center-meta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 7px; color: var(--ui-muted); font-size: 12px; }
body[data-ui-version="20"] .action-center-meta strong { color: var(--ui-text); }
body[data-ui-version="20"] .action-center-controls { display: flex; align-items: center; gap: 7px; }
body[data-ui-version="20"] .action-snooze-menu .action-menu-panel { min-width: 150px; }
body[data-ui-version="20"] .action-snooze-menu form,
body[data-ui-version="20"] .action-snooze-menu button { width: 100%; }
body[data-ui-version="20"] .action-snooze-menu button { border: 0; background: transparent; color: var(--ui-text); padding: 8px 10px; text-align: left; border-radius: 7px; cursor: pointer; }
body[data-ui-version="20"] .action-snooze-menu button:hover { background: var(--ui-surface-soft); }

body[data-ui-version="20"] .portal-search-page-form { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 10px; margin: 18px 0; }
body[data-ui-version="20"] .portal-search-page-form input { min-height: 50px; font-size: 15px; }
body[data-ui-version="20"] .search-results-summary { margin: 0 0 12px; color: var(--ui-muted); }
body[data-ui-version="20"] .search-results-page { display: grid; gap: 12px; }
body[data-ui-version="20"] .search-result-list { display: grid; }
body[data-ui-version="20"] .search-result-row { display: grid; grid-template-columns: 110px minmax(0,1fr) auto; align-items: center; gap: 14px; min-height: 64px; padding: 10px 8px; border-top: 1px solid var(--ui-border-soft); color: var(--ui-text); text-decoration: none; }
body[data-ui-version="20"] .search-result-row:hover { background: var(--ui-surface-soft); }
body[data-ui-version="20"] .search-result-kind { color: var(--ui-muted); font-size: 10px; font-weight: 750; text-transform: uppercase; }
body[data-ui-version="20"] .search-result-content { min-width: 0; display: grid; gap: 3px; }
body[data-ui-version="20"] .search-result-content strong,
body[data-ui-version="20"] .search-result-content small { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
body[data-ui-version="20"] .search-result-content small,
body[data-ui-version="20"] .search-result-side small { color: var(--ui-muted); }
body[data-ui-version="20"] .search-result-side { display: grid; justify-items: end; gap: 3px; }
body[data-ui-version="20"] .search-start-card { display: grid; gap: 14px; }
body[data-ui-version="20"] .search-hint-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; }
body[data-ui-version="20"] .search-hint-grid span { padding: 10px 12px; border: 1px solid var(--ui-border-soft); border-radius: 9px; background: var(--ui-surface-soft); color: var(--ui-muted); }

@media (max-width: 980px) {
  body[data-ui-version="20"] .app-toolbar { display: none; }
  body[data-ui-version="20"] .dashboard-main-grid { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .action-summary-grid { grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .action-center-filters { grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .action-center-filters .field.grow { grid-column: 1 / -1; }
}

@media (max-width: 680px) {
  body[data-ui-version="20"] .dashboard-hero { grid-template-columns: 1fr; padding: 18px; }
  body[data-ui-version="20"] .dashboard-action-total { min-width: 0; }
  body[data-ui-version="20"] .dashboard-hero-actions .button.ghost:nth-of-type(n+3) { display: none; }
  body[data-ui-version="20"] .dashboard-role-kpis { grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .calendar-dashboard-layout { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .action-summary-grid { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .action-center-filters { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .action-center-filters .field.grow { grid-column: auto; }
  body[data-ui-version="20"] .action-center-item { grid-template-columns: auto minmax(0,1fr); align-items: start; }
  body[data-ui-version="20"] .action-center-controls { grid-column: 2; justify-content: flex-start; flex-wrap: wrap; }
  body[data-ui-version="20"] .global-search-modal { padding: 58px 8px 8px; }
  body[data-ui-version="20"] .global-search-dialog { max-height: calc(100vh - 66px); border-radius: 13px; }
  body[data-ui-version="20"] .global-search-head { padding: 14px 14px 10px; }
  body[data-ui-version="20"] .global-search-form { margin: 0 12px 8px; }
  body[data-ui-version="20"] .global-search-result { grid-template-columns: 66px minmax(0,1fr); }
  body[data-ui-version="20"] .global-search-result-side { display: none; }
  body[data-ui-version="20"] .global-search-footer { padding: 9px 14px; }
  body[data-ui-version="20"] .portal-search-page-form { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .search-result-row { grid-template-columns: 76px minmax(0,1fr); }
  body[data-ui-version="20"] .search-result-side { display: none; }
  body[data-ui-version="20"] .search-hint-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 430px) {
  body[data-ui-version="20"] .dashboard-role-kpis { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .dashboard-action-row { grid-template-columns: auto minmax(0,1fr); }
  body[data-ui-version="20"] .dashboard-action-amount { grid-column: 2; }
  body[data-ui-version="20"] .search-hint-grid { grid-template-columns: 1fr; }
}

/* EVENT86 v20.11: project workspace */
body[data-ui-version="20"] .project-detail-page { display: block; }
body[data-ui-version="20"] .project-hero { align-items: flex-start; gap: 18px; }
body[data-ui-version="20"] .project-primary-actions { flex-wrap: wrap; justify-content: flex-end; }
body[data-ui-version="20"] .project-primary-actions form { margin: 0; }
body[data-ui-version="20"] .project-stage-toolbar {
  display: grid;
  grid-template-columns: minmax(280px,.85fr) minmax(320px,1.15fr);
  gap: 12px;
  align-items: stretch;
  margin: 14px 0;
}
body[data-ui-version="20"] .project-stage-toolbar > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 68px;
  padding: 12px 14px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 12px;
  background: var(--ui-surface);
}
body[data-ui-version="20"] .project-stage-toolbar .inline-form { display: flex; align-items: center; gap: 8px; margin: 0; }
body[data-ui-version="20"] .project-stage-toolbar select { min-width: 190px; }
body[data-ui-version="20"] .project-next-action { border-left: 4px solid var(--ui-border) !important; }
body[data-ui-version="20"] .project-next-action.is-ok { border-left-color: var(--ui-success) !important; }
body[data-ui-version="20"] .project-next-action.is-warning { border-left-color: var(--ui-warning) !important; }
body[data-ui-version="20"] .project-next-action.is-danger { border-left-color: var(--ui-danger) !important; }
body[data-ui-version="20"] .project-next-action > span,
body[data-ui-version="20"] .project-next-action > strong { display: block; }
body[data-ui-version="20"] .project-next-action strong { text-align: right; }
body[data-ui-version="20"] .project-workspace-tabs {
  position: sticky;
  top: 8px;
  z-index: 18;
  display: flex;
  gap: 5px;
  overflow-x: auto;
  margin: 0 0 12px;
  padding: 6px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 13px;
  background: color-mix(in srgb, var(--ui-surface) 94%, transparent);
  box-shadow: 0 8px 24px color-mix(in srgb, #000 8%, transparent);
  backdrop-filter: blur(14px);
}
body[data-ui-version="20"] .project-workspace-tabs button {
  flex: 0 0 auto;
  min-height: 38px;
  padding: 8px 13px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--ui-muted);
  font: inherit;
  font-size: 13px;
  font-weight: 720;
  cursor: pointer;
}
body[data-ui-version="20"] .project-workspace-tabs button:hover { background: var(--ui-surface-soft); color: var(--ui-text); }
body[data-ui-version="20"] .project-workspace-tabs button.is-active {
  background: var(--ui-brand);
  color: var(--ui-brand-contrast, #fff);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--ui-brand) 25%, transparent);
}
body[data-ui-version="20"] .project-workspace-summary {
  display: grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 9px;
  margin-bottom: 12px;
}
body[data-ui-version="20"] .project-workspace-summary > a {
  display: grid;
  gap: 4px;
  min-height: 102px;
  padding: 13px 14px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 12px;
  background: var(--ui-surface);
  color: var(--ui-text);
  text-decoration: none;
}
body[data-ui-version="20"] .project-workspace-summary > a:hover { border-color: var(--ui-brand); background: var(--ui-surface-raised); }
body[data-ui-version="20"] .project-workspace-summary span { color: var(--ui-muted); font-size: 12px; }
body[data-ui-version="20"] .project-workspace-summary strong { font-size: 24px; line-height: 1.1; }
body[data-ui-version="20"] .project-workspace-summary small { color: var(--ui-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
body[data-ui-version="20"] .project-workspace-panel[hidden],
body[data-ui-version="20"] .project-workspace-panel.is-hidden { display: none !important; }
body[data-ui-version="20"] .project-main-data-form { grid-template-columns: repeat(2,minmax(0,1fr)); }
body[data-ui-version="20"] .project-extra-data {
  padding: 10px 12px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 10px;
  background: var(--ui-surface-soft);
}
body[data-ui-version="20"] .project-extra-data > summary { cursor: pointer; font-weight: 720; }
body[data-ui-version="20"] .project-payroll-grid {
  display: grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 9px;
}
body[data-ui-version="20"] .project-payroll-grid > div {
  display: grid;
  gap: 5px;
  min-height: 94px;
  padding: 13px;
  border: 1px solid var(--ui-border-soft);
  border-radius: 11px;
  background: var(--ui-surface-soft);
}
body[data-ui-version="20"] .project-payroll-grid span,
body[data-ui-version="20"] .project-payroll-grid small { color: var(--ui-muted); }
body[data-ui-version="20"] .project-payroll-grid strong { font-size: 20px; }
body[data-ui-version="20"] .bank-reconcile-link-form [data-bank-estimate-item-select],
body[data-ui-version="20"] .bank-reconcile-link-form [data-bank-estimate-group-select] { width: 100%; }

@media (max-width: 980px) {
  body[data-ui-version="20"] .project-stage-toolbar { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .project-workspace-summary { grid-template-columns: 1fr 1fr; }
  body[data-ui-version="20"] .project-payroll-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 680px) {
  body[data-ui-version="20"] .project-hero { display: grid; }
  body[data-ui-version="20"] .project-primary-actions { justify-content: flex-start; }
  body[data-ui-version="20"] .project-stage-toolbar > div { align-items: flex-start; flex-direction: column; }
  body[data-ui-version="20"] .project-stage-toolbar .inline-form { width: 100%; align-items: stretch; flex-direction: column; }
  body[data-ui-version="20"] .project-stage-toolbar select { min-width: 0; width: 100%; }
  body[data-ui-version="20"] .project-next-action strong { text-align: left; }
  body[data-ui-version="20"] .project-workspace-tabs { top: 4px; margin-inline: -2px; }
  body[data-ui-version="20"] .project-workspace-tabs button { min-height: 42px; }
  body[data-ui-version="20"] .project-workspace-summary,
  body[data-ui-version="20"] .project-payroll-grid,
  body[data-ui-version="20"] .project-main-data-form { grid-template-columns: 1fr; }
  body[data-ui-version="20"] .project-workspace-summary > a { min-height: 88px; }
}
