/* СтройУчет desktop application styles. */
:root{
  --green:#16A34A;--green-d:#15803D;--green-l:#DCFCE7;--green-bg:#F0FDF4;
  --selected-bg:#F8FAFC;--selected-ring:0 0 0 3px var(--green-l);
  --bg:#F8FAFC;--card:#fff;--border:#E2E8F0;--text:#0F172A;--muted:#64748B;
  --red:#DC2626;--red-l:#FEE2E2;--amber:#D97706;--amber-l:#FEF3C7;--blue:#2563EB;--blue-l:#DBEAFE;
  --shadow:0 1px 2px rgba(0,0,0,.04);--shadow-m:0 4px 12px rgba(0,0,0,.08);
  --kpi-height:88px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-y:scroll;scrollbar-gutter:stable}
body{font-family:-apple-system,'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;display:flex;min-height:100vh}
body.auth-pending .sidebar,
body.auth-pending .main{visibility:hidden}

/* SIDEBAR */
.sidebar{width:240px;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:width .18s ease,box-shadow .18s ease}
.logo{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.logo-icon{width:36px;height:36px;background:var(--green);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.logo-text{font-weight:700;font-size:16px}
.logo-text small{display:block;font-size:11px;color:var(--muted);font-weight:400}
.nav{padding:12px 8px;flex:1;overflow-y:auto}
.nav-item{display:grid;grid-template-columns:18px minmax(0,1fr) max-content;align-items:center;column-gap:10px;min-height:40px;padding:10px 12px;border-radius:8px;cursor:pointer;color:var(--muted);font-weight:500;margin-bottom:2px;transition:background .15s,color .15s,box-shadow .15s,opacity .15s,transform .15s,padding-left .15s,padding-right .15s;position:relative}
.nav-item:hover{background:var(--selected-bg);color:var(--green-d);box-shadow:inset 0 0 0 1px #D9E3EF;padding-left:14px;padding-right:34px}
.nav-item.active{background:var(--selected-bg);color:var(--green-d);box-shadow:inset 0 0 0 2px var(--green)}
.nav-item[draggable="true"]{user-select:none}
.nav-item.nav-dragging{opacity:.45;transform:scale(.98);padding-left:14px;padding-right:34px}
.nav-item.nav-drop-before{box-shadow:inset 0 2px 0 var(--green)}
.nav-item.nav-drop-after{box-shadow:inset 0 -2px 0 var(--green)}
.nav-item .ico{width:18px;text-align:center}
.nav-item span:not(.ico):not(.nav-badge):not(.nav-drag-handle){min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-drag-handle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:14px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;line-height:1;cursor:grab;opacity:0;transition:opacity .12s,color .12s;pointer-events:auto}
.nav-item:hover .nav-drag-handle,.nav-item.nav-dragging .nav-drag-handle{opacity:1}
.nav-drag-handle:active{cursor:grabbing;color:var(--green-d)}
.nav-badge{justify-self:end;background:var(--red-l);color:var(--red);font-size:11px;padding:2px 6px;border-radius:10px;font-weight:600;white-space:nowrap}
.nav-item.active .nav-badge{background:var(--red-l);color:var(--red)}
.user{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;transition:background .15s}
.user:hover{background:var(--green-bg)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--green-l);color:var(--green-d);display:flex;align-items:center;justify-content:center;font-weight:700}
.user-info{flex:1;overflow:hidden}
.user-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:11px;color:var(--muted)}

/* MAIN */
.main{flex:1;min-width:0}
.topbar{height:60px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:10}
.topbar h1{font-size:18px;font-weight:700}
.topbar .spacer{flex:1}
.search{width:320px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:var(--bg)}
.search.active{border-color:var(--green);box-shadow:0 0 0 3px var(--green-l);background:#fff}
.global-search-box{position:relative;width:360px;max-width:42vw}
.global-search-box .search{width:100%}
.global-search-results{position:absolute;z-index:90;top:calc(100% + 8px);left:0;width:min(680px,calc(100vw - 80px));max-height:70vh;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 18px 42px rgba(15,23,42,.18);padding:8px}
.global-search-results[hidden]{display:none}
.global-search-result{display:grid;grid-template-columns:94px minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px;border-radius:10px;cursor:pointer;border:1px solid transparent}
.global-search-result:hover{background:var(--selected-bg);border-color:var(--green)}
.global-search-section{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:3px 8px;border-radius:999px;background:#eef6ff;color:#1d4f8f;font-size:11px;font-weight:700;white-space:nowrap}
.global-search-title{font-weight:700;font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.global-search-meta{font-size:12px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.global-search-open{font-size:12px;color:var(--green-d);font-weight:700}
.global-search-empty{padding:16px;color:var(--muted);font-size:13px;text-align:center}
.btn{padding:8px 14px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px;font-family:inherit}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-d)}
.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--bg)}
.btn-ghost{background:transparent;color:var(--muted)}
.btn-ghost:hover{background:var(--bg);color:var(--text)}
.btn-income{background:var(--green-l);color:var(--green-d);border:1px solid #A7F3D0}
.btn-income:hover{background:#D1FAE5}
.btn-income.active{background:var(--selected-bg);color:var(--green-d);border-color:var(--green);box-shadow:var(--selected-ring)}
.btn-expense{background:var(--red-l);color:var(--red);border:1px solid #FECACA}
.btn-expense:hover{background:#FEE2E2}
.btn-expense.active{background:#fff7f7;color:var(--red);border-color:var(--red);box-shadow:0 0 0 3px rgba(239,68,68,.16)}
.btn-danger-soft{background:#fff;color:var(--red);border:1px solid #FECACA}
.btn-danger-soft:hover{background:#FEF2F2;border-color:#FCA5A5}
.btn-transfer{background:var(--blue-l);color:var(--blue);border:1px solid #BFDBFE}
.btn-transfer:hover{background:#DBEAFE}
.btn-transfer.active{background:#f8fbff;color:var(--blue);border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.16)}

.content{padding:24px 28px;max-width:1400px}
.page{display:none}
.page.active{display:block}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.page-head h2{font-size:22px;font-weight:700}
.page-head p{color:var(--muted);font-size:13px;margin-top:2px}
.page-head-main{flex:1 1 auto;min-width:0}
.page-title-tools{display:flex;align-items:center;gap:8px;min-width:0;width:100%}
.page-title-tools h2{display:inline-flex;align-items:center;margin:0;line-height:1.2}
.page-title-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;margin-left:auto}
.page-title-actions .btn{min-height:34px;white-space:nowrap}
.page-settings-wrap{position:relative;display:inline-flex;align-items:center}
.page-settings-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--muted);font-size:14px;line-height:1;cursor:pointer}
.page-settings-btn:hover,.page-settings-btn.active{border-color:var(--green);color:var(--green-d);background:var(--selected-bg);box-shadow:var(--selected-ring)}
.page-settings-menu{position:absolute;z-index:60;top:calc(100% + 8px);left:0;width:260px;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff;box-shadow:0 16px 36px rgba(15,23,42,.16)}
.page-settings-menu[hidden]{display:none}
.page-settings-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.page-settings-note{font-size:12px;color:var(--muted);line-height:1.35;margin-top:10px}
.page-settings-actions{display:flex;flex-direction:column;gap:8px}
.page-settings-actions .btn{width:100%;justify-content:flex-start;min-height:36px}
.view-switch.view-switch-vertical{display:flex;flex-direction:column;width:100%;border-radius:10px}
.view-switch.view-switch-vertical .view-switch-btn{justify-content:flex-start;width:100%;border-right:none;border-bottom:1px solid var(--border);padding:9px 10px}
.view-switch.view-switch-vertical .view-switch-btn:last-child{border-bottom:none}

/* DASHBOARD */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:var(--kpi-height);gap:12px;margin-bottom:16px}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:9px 14px;box-shadow:var(--shadow);height:var(--kpi-height);min-height:var(--kpi-height);min-width:0;container-type:inline-size;display:flex;flex-direction:column;justify-content:center;gap:3px;overflow:hidden}
.kpi.clickable{cursor:pointer}
.kpi.clickable:hover{border-color:var(--green);box-shadow:var(--shadow-m)}
.kpi.clickable.active{background:var(--selected-bg);border-color:var(--green);box-shadow:var(--selected-ring)}
.section-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:var(--kpi-height);gap:12px;margin-bottom:14px}
.section-kpi-grid .kpi{min-height:var(--kpi-height)}
.finance-summary{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:var(--kpi-height);gap:12px;margin-bottom:14px}
.finance-summary .kpi{min-height:var(--kpi-height)}
.finance-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.finance-filterbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.finance-filterbar .field{min-width:220px}
.kpi-label{color:var(--muted);font-size:clamp(10px,5cqw,12px);font-weight:700;text-transform:uppercase;letter-spacing:0;line-height:1.1;min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kpi-value{font-size:clamp(18px,11cqw,26px);font-weight:700;letter-spacing:0;line-height:1.25;white-space:nowrap;min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums}
.kpi-value.neg{color:var(--red)}
.kpi-value.pos{color:var(--green)}
.kpi-value.warn{color:var(--amber)}
.kpi-delta{font-size:clamp(10px,5cqw,12px);line-height:1.25;color:var(--muted);min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kpi-delta.up{color:var(--green)}
.kpi-delta.down{color:var(--red)}

.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;margin-bottom:20px}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:var(--shadow)}
.card h3{font-size:15px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}
.card h3 .link{color:var(--green);font-size:12px;font-weight:500;cursor:pointer;text-decoration:none}

/* BALANCE BARS */
.bal-row{display:grid;grid-template-columns:minmax(0,1fr) max-content;align-items:center;gap:12px;min-height:38px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;position:relative;border-radius:8px;transition:all .15s;flex-wrap:nowrap}
.bal-row:hover:not(.total){background:var(--selected-bg);box-shadow:inset 0 0 0 1px #D9E3EF;padding-left:8px;padding-right:8px}
.bal-row:last-child{border:none}
.bal-row.total{font-weight:700;border-top:2px solid var(--text);margin-top:6px;padding-top:12px}
.bal-row[draggable="true"]{user-select:none}
.bal-row.bal-dragging{opacity:.45}
.bal-row.bal-drop-before{box-shadow:inset 0 2px 0 var(--green)}
.bal-row.bal-drop-after{box-shadow:inset 0 -2px 0 var(--green)}
.bal-label{display:flex;align-items:center;gap:8px;min-width:0;flex:1 1 auto;overflow:hidden}
.bal-label>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bal-drag-handle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:18px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;line-height:1;cursor:grab;opacity:0;transition:opacity .12s,color .12s;pointer-events:auto;z-index:6}
.bal-row:hover .bal-drag-handle,.bal-row.bal-dragging .bal-drag-handle{opacity:1}
.bal-drag-handle:active{cursor:grabbing;color:var(--green-d)}
.bal-side{display:grid;align-items:center;justify-content:end;justify-self:end;width:max-content;column-gap:0;min-width:0;padding-right:0;white-space:nowrap;transition:padding-right .15s}
.bal-side-reconcile{grid-template-columns:206px 126px}
.bal-side-action-only{grid-template-columns:126px}
.bal-side-plain{grid-template-columns:126px}
.bal-row:hover .bal-side,.bal-row.bal-dragging .bal-side{padding-right:30px}
.bal-row .val{flex:0 0 auto;justify-self:end;text-align:right;font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}
.bal-amount-cell{display:flex;align-items:center;justify-content:flex-end;min-width:0;width:126px}
.bal-reconcile-slot{display:flex;justify-content:flex-end;min-width:0;margin-right:6px}
.bal-reconcile-action{display:flex;justify-content:center;width:0;min-width:0;margin-right:0;overflow:visible}
.bal-row:hover .bal-reconcile-slot,.bal-row.bal-dragging .bal-reconcile-slot{margin-right:14px}
.bal-row:hover .bal-reconcile-action,.bal-row.bal-dragging .bal-reconcile-action{width:24px;min-width:24px;margin-right:8px}
.bal-row .val.neg{color:var(--red)}
.bal-row .val.pos{color:var(--green)}
.bal-reconcile-status{display:inline-flex;align-items:center;max-width:206px;box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:2px 7px;border:1px solid #bbf7d0;border-radius:999px;background:#f0fdf4;color:var(--green-d);font-size:10.5px;font-weight:650;line-height:1.15}
.bal-reconcile-status.warning{border-color:#fed7aa;background:#fff7ed;color:var(--amber)}
.bal-reconcile-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid #bbf7d0;border-radius:50%;background:#fff;color:var(--green-d);font-size:14px;font-weight:900;line-height:1;cursor:pointer;opacity:0;transform:scale(.92);transition:opacity .12s,transform .12s,background .12s,border-color .12s}
.bal-row:hover .bal-reconcile-btn,.bal-reconcile-btn:focus-visible{opacity:1;transform:scale(1)}
.bal-reconcile-btn:hover{background:#dcfce7;border-color:var(--green)}
.bal-reconcile-btn:disabled{opacity:.55;cursor:wait}
.dashboard-row-link{cursor:pointer}
.dashboard-row-link .bal-label>span:last-child,.dashboard-row-link .acc-name{color:var(--green-d)}
.dashboard-row-link:hover .bal-label>span:last-child,.dashboard-row-link:hover .acc-name{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
@media(max-width:820px){
  .bal-row{grid-template-columns:minmax(0,1fr) max-content}
  .bal-side-reconcile{grid-template-columns:176px 104px}
  .bal-side-action-only{grid-template-columns:104px}
  .bal-side-plain{grid-template-columns:104px}
  .bal-amount-cell{width:104px}
  .bal-reconcile-status{max-width:176px}
}

/* ACCOUNTS */
.acc-list{display:flex;flex-direction:column;gap:10px}
.acc-group{display:flex;flex-direction:column;gap:8px;position:relative;border-radius:10px;transition:background .15s,box-shadow .15s,opacity .15s}
.acc-group::after{content:"";position:absolute;inset:-1px;border-radius:11px;box-shadow:0 0 0 1px #D9E3EF;opacity:0;pointer-events:none;z-index:5;transition:opacity .15s}
.acc-group+.acc-group{margin-top:4px;padding-top:8px;border-top:1px solid var(--border)}
.acc-group:has(.acc-group-title:hover)::after,.acc-group:has(.acc-group-drag-handle:hover)::after,.acc-group.acc-group-dragging::after{opacity:1}
.acc-group:has(.acc-group-title:hover) .acc-item,.acc-group:has(.acc-group-drag-handle:hover) .acc-item,.acc-group.acc-group-dragging .acc-item,.acc-group.acc-group-drop-before .acc-item,.acc-group.acc-group-drop-after .acc-item{padding-left:14px;padding-right:24px}
.acc-group-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:3px 28px 3px 8px;display:flex;align-items:center;justify-content:flex-start;gap:8px;cursor:default;border-radius:8px;transition:background .15s,box-shadow .15s,color .15s}
.acc-group-title:hover{color:var(--green-d)}
.acc-group:has(.acc-group-title:hover) .acc-group-title,.acc-group:has(.acc-group-drag-handle:hover) .acc-group-title,.acc-group.acc-group-dragging .acc-group-title{color:var(--green-d)}
.acc-group-drag-handle{position:absolute;right:8px;top:10px;width:14px;height:20px;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;color:var(--muted);cursor:grab;opacity:0;transition:opacity .12s,color .12s;pointer-events:auto;z-index:6}
.acc-group:has(.acc-group-title:hover) .acc-group-drag-handle,.acc-group:has(.acc-group-drag-handle:hover) .acc-group-drag-handle,.acc-group.acc-group-dragging .acc-group-drag-handle,.acc-group.acc-group-drop-before .acc-group-drag-handle,.acc-group.acc-group-drop-after .acc-group-drag-handle{opacity:1}
.acc-group.acc-group-dragging{opacity:.55}
.acc-group.acc-group-drop-before{box-shadow:0 -2px 0 var(--green)}
.acc-group.acc-group-drop-after{box-shadow:0 2px 0 var(--green)}
.acc-item{display:grid;grid-template-columns:38px minmax(0,1fr) max-content;align-items:center;column-gap:12px;padding:10px;margin-left:0;margin-right:0;background:var(--bg);border-radius:8px;position:relative;transform-origin:center;transition:background .15s,box-shadow .15s,opacity .15s,transform .15s,padding-left .15s,padding-right .15s,margin-left .15s,margin-right .15s}
.acc-item:hover{background:var(--selected-bg);box-shadow:inset 0 0 0 1px #D9E3EF;padding-left:18px;padding-right:32px}
.acc-item[draggable="true"]{user-select:none}
.acc-item.acc-dragging{opacity:.45;transform:scale(.99);padding-left:18px;padding-right:32px}
.acc-item.acc-drop-before{box-shadow:inset 0 2px 0 var(--green);padding-left:18px;padding-right:32px}
.acc-item.acc-drop-after{box-shadow:inset 0 -2px 0 var(--green);padding-left:18px;padding-right:32px}
.acc-drag-handle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:14px;height:22px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:15px;line-height:1;cursor:grab;opacity:0;transition:opacity .12s,color .12s;pointer-events:auto;z-index:6}
.acc-item:hover .acc-drag-handle,.acc-item.acc-dragging .acc-drag-handle{opacity:1}
.acc-drag-handle:active{cursor:grabbing;color:var(--green-d)}
.nav-drag-handle:hover,.bal-drag-handle:hover,.acc-group-drag-handle:hover,.acc-drag-handle:hover{color:var(--green-d);cursor:grab}
.nav-drag-handle:active,.bal-drag-handle:active,.acc-group-drag-handle:active,.acc-drag-handle:active{cursor:grabbing;color:var(--green-d)}
.acc-ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--green-l);color:var(--green-d)}
.acc-ico-img,.acc-ico-logo{overflow:hidden;background:#fff;color:inherit}
.acc-ico-logo{padding:0;box-sizing:border-box}
.acc-ico-img img{width:100%;height:100%;object-fit:cover;display:block}
.acc-ico-logo img,.acc-ico-logo svg{width:100%;height:100%;object-fit:cover;display:block}
.acc-info{min-width:0;max-width:100%;overflow:hidden}
.acc-name{font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acc-type{color:var(--muted);font-size:11px}
.acc-bal{justify-self:end;font-weight:700;font-variant-numeric:tabular-nums;font-size:14px;text-align:right;white-space:nowrap}
.acc-bal.neg{color:var(--red)}

/* TABLE */
.table-wrap{--table-head-sticky-top:60px;background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:visible;box-shadow:var(--shadow)}
.table-top{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.table-top b{font-size:15px}
.table-wrap>table{background:var(--card);border-radius:0 0 12px 12px}
.table-top.table-sticky{position:sticky;top:60px;z-index:8;background:#fff}
.table-top.table-sticky:first-child{border-radius:12px 12px 0 0}
.table-actions{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.summary-panel{margin-bottom:16px}
.summary-panel.collapsed{display:none}
.summary-panel.collapsed .summary-panel-body{display:none}
.summary-toggle-inline{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;margin-left:8px;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--muted);font-size:14px;line-height:1;vertical-align:middle;cursor:pointer}
.summary-toggle-inline:hover{border-color:var(--green);color:var(--green-d);background:var(--selected-bg)}
.table-filter-chip-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-left:auto}
.filter-chip{padding:6px 12px;border:1px solid var(--border);border-radius:20px;background:#fff;cursor:pointer;font-size:12px;font-weight:500;color:var(--muted)}
.filter-chip:hover{border-color:var(--green)}
.filter-chip.active{background:var(--selected-bg);color:var(--green-d);border-color:var(--green);box-shadow:var(--selected-ring)}
.journal-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:var(--kpi-height);gap:12px;margin-bottom:14px}
.journal-kpi-grid .kpi{min-height:var(--kpi-height)}
.journal-toolbar{display:grid;grid-template-columns:auto auto minmax(260px,360px) minmax(120px,1fr) auto;align-items:center}
.journal-status-row{padding-top:0;background:#fff}
.journal-status-row .table-filter-chip-row{margin-left:0}
.journal-status-label{font-size:12px;color:var(--muted);font-weight:700}
.settings-pane{background:var(--card);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.settings-pane-head{display:flex;justify-content:space-between;align-items:center;padding:14px 20px 12px;gap:16px}
.settings-pane-groups{display:flex;align-items:center;gap:14px;flex-wrap:wrap;min-height:44px}
.settings-pane-groups-label{font-size:18px;font-weight:500;color:var(--text);cursor:help}
.settings-chip{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 16px;border:1px solid #D9E3EF;border-radius:999px;background:#fff;color:#5C7695;cursor:pointer;font-size:13px;font-weight:600;transition:border-color .15s,color .15s,background .15s}
.settings-chip:hover{border-color:var(--green);color:var(--green-d)}
.settings-chip.active{background:var(--selected-bg);border-color:var(--green);color:var(--green-d);box-shadow:var(--selected-ring)}
.settings-group-row{display:flex;gap:8px;flex-wrap:wrap}
.settings-groups-divider{height:1px;width:390px;max-width:100%;background:var(--border);margin:8px 0 0 20px}
.settings-table th.settings-head-action{cursor:pointer;color:var(--green-d)}
.settings-head-link{display:inline-flex;align-items:center;gap:6px;color:var(--green-d);font-weight:700;text-decoration:underline dotted rgba(22,163,74,.45);text-underline-offset:3px;cursor:pointer;transition:color .12s ease,text-decoration-color .12s ease}
.settings-head-link::after{content:"ред.";display:inline-flex;align-items:center;justify-content:center;padding:1px 6px;border-radius:999px;background:rgba(22,163,74,.10);color:var(--green-d);font-size:10px;font-weight:700;line-height:1;text-transform:uppercase;letter-spacing:.02em}
.settings-table th.settings-head-action:hover .settings-head-link{color:var(--green);text-decoration-color:rgba(22,163,74,.9)}
.settings-table th.settings-sortable{cursor:pointer}
.settings-table tbody tr.is-archived{opacity:.6}
.settings-table td.muted{color:var(--muted)}
.settings-accounts-wrap{padding:0;overflow:hidden}
.settings-accounts-wrap .table-top.table-sticky{position:static !important;top:auto !important}
.settings-accounts-toolbar{display:flex}
.settings-accounts-toolbar>b{white-space:nowrap}
.settings-accounts-toolbar .table-filter-chip-row{flex-basis:100%;margin-left:0;order:10}
.settings-table-count{color:var(--muted);font-size:12px;white-space:nowrap}
.settings-accounts-note{padding:10px 16px;border-bottom:1px solid var(--border);color:var(--muted);font-size:12px;line-height:1.35;background:#fff}
.settings-accounts-table-shell{overflow:auto;background:#fff}
.settings-accounts-table{min-width:1040px;table-layout:fixed}
.settings-accounts-table th,.settings-accounts-table td{font-size:13px;line-height:1.28;padding:12px 24px;vertical-align:middle;overflow:hidden;transition:background .15s,color .15s,padding-left .15s,padding-right .15s}
.settings-accounts-table th{font-size:10px;line-height:1.1;padding:9px 24px;font-weight:650}
.settings-accounts-table tbody tr.settings-account-row{height:66px;cursor:pointer;transition:background .15s,box-shadow .15s,opacity .15s,transform .15s}
.settings-accounts-table tbody tr.settings-account-row:hover{background:var(--selected-bg);box-shadow:inset 0 0 0 1px #D9E3EF;color:var(--green-d)}
.settings-accounts-table tbody tr.settings-account-row:hover td{background:var(--selected-bg)}
.settings-account-row:hover td:first-child,.settings-account-row-dragging td:first-child,.settings-account-row-drop-before td:first-child,.settings-account-row-drop-after td:first-child{padding-left:34px}
.settings-account-row:hover td:last-child,.settings-account-row-dragging td:last-child,.settings-account-row-drop-before td:last-child,.settings-account-row-drop-after td:last-child{padding-right:64px !important}
.settings-accounts-table tbody tr.settings-account-row-dragging{opacity:.45;transform:scale(.998)}
.settings-accounts-table tbody tr.settings-account-row-drop-before{box-shadow:inset 0 2px 0 var(--green)}
.settings-accounts-table tbody tr.settings-account-row-drop-after{box-shadow:inset 0 -2px 0 var(--green)}
.settings-account-col-name{width:28%}
.settings-account-col-bank{width:28%}
.settings-account-col-kind{width:16%}
.settings-account-col-balance{width:14%}
.settings-account-col-meta{width:14%}
.settings-account-name-cell{position:relative}
.settings-account-meta-cell{position:relative !important;padding-right:48px !important;overflow:visible !important}
.settings-account-row:hover .settings-account-meta-cell,.settings-account-row-dragging .settings-account-meta-cell,.settings-account-row-drop-before .settings-account-meta-cell,.settings-account-row-drop-after .settings-account-meta-cell{padding-right:64px !important}
.settings-account-main{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.settings-account-row:hover .settings-account-main{color:var(--green-d)}
.settings-account-sub{font-size:12px;color:var(--muted);line-height:1.2;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}
.settings-account-amount{font-weight:500;white-space:nowrap;color:var(--text);font-variant-numeric:tabular-nums}
.settings-account-row:hover .settings-account-amount,.settings-account-row:hover .settings-account-sub{color:var(--green-d)}
.settings-account-drag-handle{position:absolute;right:18px;top:50%;transform:translateY(-50%);width:14px;height:22px;border:0;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;line-height:1;cursor:grab;opacity:0;transition:opacity .12s,color .12s;pointer-events:auto;z-index:6}
.settings-account-drag-handle::before{content:"☰"}
.settings-account-drag-handle:hover{color:var(--green-d)}
.settings-account-drag-handle:active{cursor:grabbing;color:var(--green-d)}
.settings-account-row:hover .settings-account-drag-handle,.settings-account-row-dragging .settings-account-drag-handle,.settings-account-row-drop-before .settings-account-drag-handle,.settings-account-row-drop-after .settings-account-drag-handle{opacity:1}
.settings-accounts-table th:last-child,.settings-accounts-table td:last-child{position:static !important;right:auto !important;box-shadow:none !important}
.settings-accounts-table td.settings-account-meta-cell{position:relative !important}
.settings-accounts-table thead th:last-child{background:#F8FAFC !important}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--bg);text-align:left;padding:12px 22px;font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border)}
tbody td{padding:16px 22px;border-bottom:1px solid var(--border)}
tbody tr:hover{background:var(--green-bg)}
tbody tr:last-child td{border:none}
td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.table-wrap table{min-width:0}
.table-wrap th,.table-wrap td{min-width:0}
.table-wrap th{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.table-wrap td.num,.table-wrap th.num,.table-wrap td.num *,.table-wrap th.num *{white-space:nowrap}
.table-wrap td:last-child,.table-wrap th:last-child{white-space:nowrap}
.table-wrap table th:last-child,.table-wrap table td:last-child{position:sticky;right:0;z-index:2;background:#fff;box-shadow:-1px 0 0 var(--border)}
.table-wrap table thead th:last-child{z-index:3;background:var(--bg)}
.table-wrap>table>thead th{position:sticky;top:var(--table-head-sticky-top);z-index:7}
.table-wrap>table>thead th:last-child{z-index:8}
.table-wrap td:last-child .btn,.table-wrap td:last-child .badge,.table-wrap td:last-child button,.table-wrap td:last-child a{white-space:nowrap;max-width:none;flex-shrink:0}
.table-wrap .badge{max-width:none}
.table-wrap .btn{min-width:max-content}
.table-wrap .text-priority,.table-wrap .journal-content,.table-wrap .primary-row-title,.table-wrap .journal-main-text,.table-wrap .journal-sub-text,.table-wrap .objects-main-text,.table-wrap .objects-sub-text{min-width:0}
.receivable-table{table-layout:fixed}
.receivable-table th,.receivable-table td{vertical-align:middle}
.receivable-col-contract{width:120px}
.receivable-col-client{width:auto}
.receivable-col-money{width:180px}
.receivable-col-total{width:220px}
.receivable-contract-cell{white-space:nowrap}
.receivable-client-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.receivable-expected-cell{cursor:pointer;border-radius:8px;transition:background .15s ease,box-shadow .15s ease}
.receivable-expected-cell:hover{background:#f8fafc;box-shadow:inset 0 0 0 1px var(--green)}

/* Schedule kind badge — тип графика оплат у договора */
.sched-kind-badge{display:inline-flex;align-items:center;gap:5px;padding:1px 7px;border-radius:99px;font-size:10px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;background:#dbeafe;color:#2563eb;line-height:1.4}
.sched-kind-badge.event{background:#dcfce7;color:#15803d}
.sched-kind-badge.hybrid{background:#fce7f3;color:#be185d}
.sched-kind-badge.on-fact{background:#fef3c7;color:#d97706}
.sched-kind-badge.manual{background:#fff;color:#64748b;border:1px solid #e2e8f0}
.sched-kind-badge.calendar{background:#dbeafe;color:#2563eb}

/* Contract detail row — inline-раскрытие договора в реестре */
.contracts-table.contracts-has-open tbody tr.contracts-row{opacity:.45}
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open{opacity:1;background:#eef6ff}
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open:hover{background:#eaf4ff}
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open>td{background:#eef6ff}
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open:hover>td{background:#eaf4ff}
.contracts-table tbody tr.contracts-detail-row > td{background:#f8fafc;border-top:0;padding:0 16px 14px;box-shadow:inset 4px 0 var(--green)}
.contract-detail-block{padding:14px 18px 18px}
.contract-detail-header{display:flex;justify-content:flex-end;margin-bottom:8px}
.contract-detail-actions{display:flex;gap:6px}
.contract-section{margin-top:14px}
.contract-section:first-of-type{margin-top:0}
.contract-section .section-title{font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:#64748b;margin-bottom:8px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.contract-section .section-title b{color:#0f172a;font-size:12px;font-weight:700}

.events-strip{display:flex;gap:6px;flex-wrap:wrap}
.event-chip{padding:4px 10px;border-radius:99px;font-size:11px;background:#fff;border:1px solid #e2e8f0;color:#64748b;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.event-chip.done{background:#dcfce7;color:#15803d;border-color:transparent}
.event-chip.pending{background:#fef3c7;color:#d97706;border-color:transparent}
.event-chip .ev-when{opacity:.7}

.stage-table,.schedule-table{width:100%;font-size:12px;border-collapse:collapse;background:#fff;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}
.stage-table th,.schedule-table th{text-align:left;padding:7px 10px;background:#f8fafc;color:#64748b;font-weight:600;font-size:10px;letter-spacing:.3px;text-transform:uppercase;border-bottom:1px solid #e2e8f0;white-space:nowrap}
.stage-table td,.schedule-table td{padding:8px 10px;vertical-align:top;border-bottom:1px solid #f1f5f9;background:#fff}
.stage-table tr:last-child td,.schedule-table tr:last-child td{border-bottom:none}
.stage-table td.num,.schedule-table td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.stage-table .stage-name{font-weight:600;color:#0f172a}
.stage-table .stage-no{display:inline-block;width:18px;height:18px;border-radius:50%;background:#dcfce7;color:#15803d;text-align:center;line-height:18px;font-size:11px;font-weight:700;margin-right:6px}

.constructive-chip{display:inline-block;background:#f1f5f9;color:#475569;padding:1px 6px;border-radius:4px;font-size:11px;margin:1px 3px 1px 0;white-space:nowrap}
.schedule-table .trig-icon{display:inline-block;width:18px;text-align:center;margin-right:4px}
.schedule-table .trig-icon.cal{color:#2563eb}
.schedule-table .trig-icon.evt{color:#15803d}
.schedule-table .cell-sub{font-size:11px;color:#94a3b8;margin-top:2px}
.badge.b-sm{font-size:10px;padding:1px 6px}

.cost-summary-strip{display:flex;flex-wrap:wrap;gap:10px}
.cost-stat{display:flex;flex-direction:column;gap:2px;min-width:118px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px}
.cost-stat .cost-k{font-size:10px;letter-spacing:.3px;text-transform:uppercase;color:#94a3b8}
.cost-stat .cost-v{font-size:14px;font-weight:700;color:#0f172a;font-variant-numeric:tabular-nums}
.cost-stat .cost-v.pos{color:var(--green)}
.cost-stat .cost-v.neg{color:var(--red)}
.cost-stat .cost-v.muted{color:#94a3b8;font-weight:600;font-size:12px}

/* CONTRACTS GRID */
.contracts-toolbar{display:grid;grid-template-columns:auto auto minmax(260px,430px) minmax(120px,1fr) auto;align-items:center}
.contracts-toolbar .table-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.contracts-toolbar .table-actions .btn{white-space:nowrap}
.contracts-table{table-layout:fixed;width:100%;min-width:1180px}
.contracts-table th,.contracts-table td{vertical-align:middle;overflow:hidden}
.contracts-table th{font-size:10px;line-height:1.1;padding:9px 10px}
.contracts-table td{font-size:12px;line-height:1.2;padding:10px 12px}
.contracts-table tbody tr.contracts-row{cursor:pointer;height:76px}
.contracts-table tbody tr.contracts-row > td{height:76px;max-height:76px;overflow:hidden}
.contracts-table tbody tr.contracts-row:hover{background:#f8fafc}
.contracts-table tbody tr.contracts-row:hover td:last-child{background:#f8fafc}
.contracts-main-line{display:block;max-width:100%;font-weight:500;color:var(--text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contracts-date-line{display:block;max-width:100%;font-weight:600;color:#12304f;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contracts-sub-line{display:block;max-width:100%;font-size:11px;color:var(--muted);line-height:1.2;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contracts-work-period{color:#64748b}
.contracts-warning-text{color:var(--red)}
.contracts-cell-warning{background:var(--red-l)}
.contracts-money-main{font-weight:500;color:var(--text);white-space:nowrap}
.contracts-money-cell{font-variant-numeric:tabular-nums}
.contracts-money-sub{color:#64748b}
.contracts-remaining{color:var(--amber)}
.contracts-status-cell .badge{max-width:100%;white-space:nowrap}
.contracts-status-meta{margin-top:8px;font-size:11px;line-height:1.2;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums}
.contracts-status-meta.pos{color:var(--green-d)}
.contracts-status-meta.neg{color:var(--red)}
.contracts-status-meta.muted{color:#94a3b8}
.contracts-col-contract{width:282px}
.contracts-col-object{width:auto}
.contracts-col-money{width:252px}
.contracts-col-cost{width:252px}
.contracts-col-deadline{width:198px}
.contracts-col-status{width:145px}

/* Однострочные показатели договора в реестре */
.contracts-money-ledger-cell,.contracts-cost-ledger-cell,.contracts-deadline-cell{padding:8px 12px;vertical-align:middle;font-variant-numeric:tabular-nums}
.contract-inline-indicator{position:relative;display:grid;grid-template-columns:minmax(0,1fr) max-content;align-items:center;gap:8px;min-width:0;min-height:34px;padding:6px 8px;border:1px solid #dde7f2;border-radius:8px;background:#fff;overflow:hidden}
.contract-inline-indicator::before{content:"";position:absolute;inset:0 auto 0 0;width:var(--ci-progress,0%);background:linear-gradient(90deg,rgba(22,163,74,.14),rgba(22,163,74,.05));pointer-events:none}
.contract-cost-indicator::before{background:linear-gradient(90deg,rgba(14,165,233,.13),rgba(14,165,233,.04))}
.contract-inline-indicator .ci-value{position:relative;z-index:1;display:flex;align-items:baseline;gap:4px;min-width:0;font-size:12px;line-height:1.2;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contract-inline-indicator .ci-value small{min-width:0;color:#94a3b8;font-size:10px;font-weight:600;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contract-inline-indicator .ci-main{min-width:0;overflow:hidden;text-overflow:ellipsis}
.contract-inline-indicator .ci-paid{color:var(--green-d)}
.contract-inline-indicator .ci-cost{color:#475569}
.contract-inline-indicator.is-risk .ci-cost{color:var(--red)}
.contract-inline-indicator .ci-rest{position:relative;z-index:1;min-width:0;color:#64748b;font-size:10px;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contract-inline-indicator .ci-rest.is-due{color:#c2410c}
.contract-inline-indicator .ci-rest.is-overpaid{color:#0369a1}
.contract-stage-deadline{--deadline-color:var(--green);--deadline-soft:#f0fdf4;position:relative;display:grid;grid-template-columns:minmax(0,1fr) max-content;grid-template-rows:auto 6px;align-items:center;gap:7px 8px;min-width:0;min-height:44px;padding:7px 8px 8px;border:1px solid #d9e3ef;border-radius:8px;background:linear-gradient(90deg,var(--deadline-soft),#fff 46%);overflow:hidden}
.contract-stage-deadline.is-soon{--deadline-color:var(--amber);--deadline-soft:#fff7df;border-color:#f2d48a}
.contract-stage-deadline.is-overdue{--deadline-color:var(--red);--deadline-soft:#fff0f0;border-color:#f3b4b4}
.contract-stage-deadline.is-done,.contract-stage-deadline.is-empty{--deadline-color:#64748b;--deadline-soft:#eef2f7;border-color:#d6dee9}
.contract-stage-deadline .deadline-date{min-width:0;display:flex;align-items:baseline;gap:5px;font-size:12px;font-weight:800;color:#172033;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contract-stage-deadline .deadline-date span{min-width:0;overflow:hidden;text-overflow:ellipsis}
.contract-stage-deadline .deadline-date small{min-width:0;color:#7a8aa0;font-size:10px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contract-stage-deadline .deadline-left{justify-self:end;max-width:68px;padding:3px 7px;border:1px solid rgba(100,116,139,.24);border-radius:999px;background:#fff;color:var(--deadline-color);font-size:10px;line-height:1.15;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contract-stage-deadline.is-soon .deadline-left{border-color:#f2d48a}
.contract-stage-deadline.is-overdue .deadline-left{border-color:#f3b4b4}
.contract-stage-deadline .deadline-track{position:relative;grid-column:1/-1;height:6px;border-radius:999px;background:#e6edf5;overflow:hidden}
.contract-stage-deadline .deadline-track span{display:block;width:var(--deadline-progress,0%);height:100%;border-radius:inherit;background:var(--deadline-color)}
.contract-stage-deadline .deadline-track i{position:absolute;top:50%;left:clamp(8px,var(--deadline-progress,0%),calc(100% - 8px));width:10px;height:10px;transform:translate(-50%,-50%);border:2px solid #fff;border-radius:999px;background:var(--deadline-color);box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.contract-stage-deadline.is-empty .deadline-track span,.contract-stage-deadline.is-empty .deadline-track i{display:none}

.badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap;line-height:1.15;min-height:20px}
.b-green{background:var(--green-l);color:var(--green-d)}
.b-amber{background:var(--amber-l);color:var(--amber)}
.b-red{background:var(--red-l);color:var(--red)}
.b-blue{background:var(--blue-l);color:var(--blue)}
.b-gray{background:#F1F5F9;color:var(--muted)}
.max-profile{display:flex;align-items:center;gap:10px;min-width:0}
.max-avatar{width:38px;height:38px;border-radius:50%;background:#eef6ff;color:#1d4f8f;display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-weight:800;font-size:14px;overflow:hidden}
.max-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.max-profile-main{min-width:0}
.max-profile-title{font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}
.max-profile-meta{color:var(--muted);font-size:12px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}
.max-chat-explain{display:grid;grid-template-columns:180px 1fr;gap:12px;align-items:start;padding:12px 18px;background:#FAFBFC;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:13px;color:var(--muted)}
.max-chat-explain b{color:var(--text)}
.max-member-list{display:flex;flex-direction:column}
.max-member-card{display:grid;grid-template-columns:minmax(180px,1.05fr) minmax(220px,1fr) minmax(360px,1.6fr) 150px;gap:18px;align-items:start;padding:18px;border-bottom:1px solid var(--border);background:#fff}
.max-member-card:last-child{border-bottom:0}
.max-member-card.is-unlinked{background:#FCFCFD}
.max-link-state span,.max-link-form span{display:block;color:var(--muted);font-size:12px;line-height:1.3}
.max-link-state b{display:block;margin-top:3px;font-size:14px}
.max-link-form select{width:100%;min-width:0}
.max-permission-list{display:grid;gap:8px}
.max-permission{display:grid;grid-template-columns:18px 1fr;gap:8px;align-items:start;min-height:46px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;line-height:1.3;cursor:pointer}
.max-permission:hover{border-color:#B7C6D8;background:#F8FAFC}
.max-permission.is-on{border-color:#B8E3C8;background:#F4FBF6}
.max-permission.is-disabled{opacity:.62;cursor:not-allowed;background:#F8FAFC}
.max-permission input{margin-top:2px;accent-color:var(--green)}
.max-permission b{display:block;font-size:13px;font-weight:700;color:var(--text)}
.max-permission small{display:block;margin-top:2px;font-size:12px;color:var(--muted)}
.max-empty-permissions{padding:10px 12px;border:1px dashed var(--border);border-radius:8px;background:#F8FAFC;color:var(--muted);font-size:13px}
.max-member-action{text-align:right;white-space:nowrap}
.max-member-row{display:block;border-bottom:1px solid var(--border);background:#fff}
.max-member-row:last-child{border-bottom:0}
.max-member-row[open]{background:#FCFCFD}
.max-member-summary{display:grid;grid-template-columns:minmax(190px,1.1fr) minmax(190px,1fr) minmax(240px,1.35fr) 26px;gap:14px;align-items:center;padding:12px 18px;cursor:pointer;list-style:none}
.max-member-summary::-webkit-details-marker{display:none}
.max-member-summary:hover{background:#F8FAFC}
.max-member-employee span,.max-member-right span{display:block;color:var(--muted);font-size:12px;line-height:1.3}
.max-member-employee b{display:block;margin-top:2px;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.max-member-right{display:flex;align-items:center;justify-content:flex-end;gap:10px;min-width:0;text-align:right}
.max-member-right > span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.max-row-chevron{color:var(--muted);font-size:14px;text-align:center;transition:transform .15s ease}
.max-member-row[open] .max-row-chevron{transform:rotate(180deg)}
.max-member-details{padding:0 18px 16px 18px}
.max-member-detail-grid{display:grid;grid-template-columns:minmax(220px,1fr) minmax(360px,1.7fr) auto;gap:16px;align-items:start;padding:14px;border:1px solid var(--border);border-radius:10px;background:#fff}
.max-detail-title{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:800;margin-bottom:8px}
.max-member-details .max-member-action{align-self:end}
.max-pending-section{margin:0 0 14px;background:#fff;border:1px solid #FCD34D;border-radius:10px;overflow:hidden}
.max-pending-section > summary{display:flex;align-items:center;gap:8px;padding:12px 16px;cursor:pointer;font-weight:800;background:#FFFBEB;color:#92400E;list-style:none}
.max-pending-section > summary::-webkit-details-marker{display:none}
.max-pending-section .table-wrap{border:0;border-top:1px solid #FDE68A;border-radius:0;box-shadow:none}

/* OBJECTS GRID */
.objects-toolbar{display:grid;grid-template-columns:auto auto minmax(260px,360px) minmax(120px,1fr) auto;align-items:center}
.objects-status-row{padding-top:0;background:#fff}
.objects-status-row .table-filter-chip-row{margin-left:0}
.objects-status-label{font-size:12px;color:var(--muted);font-weight:700}
.objects-kpi-strip,
.objects-section-strip{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-rows:var(--kpi-height);gap:12px;margin-bottom:14px}
.objects-kpi-strip .kpi,
.objects-section-strip .kpi{height:var(--kpi-height);min-height:var(--kpi-height)}
.objects-table{table-layout:fixed;width:100%}
.objects-table th,.objects-table td{vertical-align:middle;overflow:hidden}
.objects-table th{font-size:10px;line-height:1.1;padding:9px 16px}
.objects-table td{font-size:12px;line-height:1.25;padding:10px 14px}
.objects-table tbody tr.object-row{cursor:pointer}
.objects-table tbody tr.object-row:hover{background:#f8fafc}
.objects-table.objects-has-open tbody tr.object-row{opacity:.45}
.objects-table.objects-has-open tbody tr.object-row.object-row-open{opacity:1;background:#eef6ff;box-shadow:inset 4px 0 var(--green)}
.objects-table.objects-has-open tbody tr.object-row.object-row-open:hover{background:#eaf4ff}
.objects-table td.num{white-space:nowrap}
.objects-main-text{font-weight:700;color:var(--text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.objects-sub-text{font-size:11px;color:var(--muted);line-height:1.2;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.objects-sub-text.object-warn{color:var(--red)}
.objects-period{font-size:11px;color:#31506f;line-height:1.2}
.objects-progress-cell{min-width:0}
.objects-actions{display:flex;justify-content:flex-end;gap:6px}
.objects-detail-row>td{background:#f8fafc;border-top:0;padding:0 16px 14px;box-shadow:inset 4px 0 var(--green)}
.objects-col-object{width:23%}
.objects-col-payment{width:21%}
.objects-col-term{width:19%}
.objects-col-state{width:15%}
.objects-col-name{width:28%}
.objects-col-status{width:15%}
.objects-col-period{width:15%}
.objects-col-contracts{width:22%}
.objects-col-money{width:13%}
.objects-col-progress{width:12%}
.objects-col-actions{width:76px}
.objects-object-visual{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center;min-width:0}
.objects-object-copy{min-width:0}
.objects-object-ico{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;background:#eff6ff;color:#2563eb;font-size:17px;font-weight:800;line-height:1}
.objects-object-ico.plot{background:#ecfdf5;color:#059669}
.objects-object-ico.machine{background:#fef3c7;color:#b45309}
.objects-object-title-row{display:flex;align-items:center;gap:9px;min-width:0}
.objects-object-title-row .objects-main-text{font-size:16px;letter-spacing:0}
.objects-object-title-row .badge{flex:0 0 auto;min-height:23px;padding:3px 10px;font-size:12px}
.objects-contract-c2{display:grid;gap:4px;min-width:0}
.objects-contract-primary{font-size:13px;font-weight:800;color:#047857;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.objects-contract-secondary{font-size:11px;color:#64748b;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.objects-contract-empty{display:flex;align-items:center;min-height:38px;color:#94a3b8;font-weight:750;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.objects-meter{position:relative;display:grid;grid-template-columns:minmax(0,1fr) max-content;gap:8px;align-items:center;min-height:42px;padding:7px 9px;border:1px solid #dbe5f0;border-radius:10px;background:#fff;overflow:hidden}
.objects-meter::before{content:"";position:absolute;inset:0 auto 0 0;width:var(--objects-meter-progress,0%);background:linear-gradient(90deg,rgba(22,163,74,.14),rgba(22,163,74,.05));pointer-events:none}
.objects-meter.time::before{background:linear-gradient(90deg,rgba(37,99,235,.12),rgba(37,99,235,.04))}
.objects-meter.warn::before{background:linear-gradient(90deg,rgba(217,119,6,.13),rgba(217,119,6,.04))}
.objects-meter.risk::before{background:linear-gradient(90deg,rgba(220,38,38,.13),rgba(220,38,38,.04))}
.objects-meter.is-empty::before{display:none}
.objects-meter b,.objects-meter small,.objects-meter span{position:relative;z-index:1;min-width:0}
.objects-meter b{display:block;font-size:12px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.objects-meter small{display:block;margin-top:2px;color:#94a3b8;font-size:10px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.objects-meter>span{font-size:10px;color:#64748b;font-weight:800;white-space:nowrap}
.objects-meter>span.due{color:#c2410c}
.objects-meter>span.warn{color:#d97706}
.objects-meter>span.risk{color:var(--red)}
.obj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.obj-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow)}
.obj-card:hover{border-color:var(--green);box-shadow:var(--shadow-m)}
.obj-head{display:flex;justify-content:space-between;align-items:start;margin-bottom:10px;gap:8px}
.obj-head>div{min-width:0}
.obj-name{font-weight:700;font-size:15px;overflow-wrap:anywhere;word-break:break-word}
.obj-type{color:var(--muted);font-size:12px;margin-top:2px;overflow-wrap:anywhere;word-break:break-word}
.obj-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0;font-size:12px}
.obj-stats .lbl{color:var(--muted);font-size:11px}
.obj-stats .vv{font-weight:700;font-variant-numeric:tabular-nums}
.progress{height:6px;background:var(--bg);border-radius:3px;overflow:hidden;margin-top:10px}
.progress>span{display:block;height:100%;background:var(--green);border-radius:3px}
.progress-info{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:6px}

/* FORM */
.form-grid{display:grid;gap:14px}
.field{display:flex;flex-direction:column;gap:6px;min-width:0}
.field label{font-size:12px;font-weight:600;color:var(--muted)}
.field input,.field select,.field textarea{width:100%;min-width:0;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-l)}
.uc-choice-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.uc-choice-field{grid-column:1 / -1;width:100%;min-width:0}
.uc-choice{min-height:74px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;text-align:left;cursor:pointer;font-family:inherit;color:var(--text);transition:border-color .15s,background .15s,box-shadow .15s}
.uc-choice:hover{border-color:var(--green);background:var(--selected-bg)}
.uc-choice.active{border-color:var(--green);background:var(--selected-bg);box-shadow:var(--selected-ring)}
.uc-choice b{display:block;font-size:14px;line-height:1.2;margin-bottom:4px}
.uc-choice span{display:block;font-size:11px;line-height:1.25;color:var(--muted)}
.uc-choice-row.uc-choice-collapsed{display:flex;align-items:center}
.uc-choice-row.uc-choice-collapsed .uc-choice:not(.active){display:none}
.uc-choice-row.uc-choice-collapsed .uc-choice.active{min-height:34px;width:auto;min-width:150px;padding:6px 12px;display:flex;align-items:center;gap:8px}
.uc-choice-row.uc-choice-collapsed .uc-choice.active b{font-size:13px;margin:0}
.uc-choice-row.uc-choice-collapsed .uc-choice.active span{display:none}
.uc-choice-row.uc-choice-collapsed .uc-choice.active::after{content:'изменить';font-size:11px;color:var(--muted);font-weight:600}
.uc-upper-summary{display:none;width:100%;min-height:38px;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border:1px solid #e6edf5;border-radius:10px;background:#fff;color:#5f7896;cursor:pointer;text-align:left;font-family:inherit}
.uc-upper-summary strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;color:#5f7896}
.uc-upper-summary span{flex-shrink:0;font-size:12px;font-weight:700;color:#5f7896}
.uc-progressive-fields{display:flex;flex-direction:column;gap:14px}
#m-accounting-card.uc-start-mode .uc-progressive-fields{display:none !important}
#m-accounting-card.uc-start-mode #uc-submit{display:none}
#m-accounting-card.uc-upper-collapsed .uc-progressive-head{display:none !important}
#m-accounting-card.uc-upper-collapsed .uc-upper-summary{display:flex}
.uc-block-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.uc-block-title{font-weight:700}
.uc-block-subtitle{font-size:12px;color:var(--muted);margin-top:2px}
.uc-block-toggle{border:1px solid #dbe4f0;border-radius:8px;background:#fff;color:#5f7896;font-size:12px;font-weight:700;padding:5px 9px;cursor:pointer;white-space:nowrap}
.uc-block-toggle:hover{border-color:var(--green);color:var(--green-d);background:var(--selected-bg)}
.uc-card-section{border:1px solid var(--border) !important;border-radius:8px !important;background:#fff !important;overflow:hidden;padding:0 !important}
.uc-card-section.uc-step-active{border-color:#22c55e !important;box-shadow:0 0 0 3px rgba(34,197,94,.12);background:#fbfffd !important}
.uc-card-section.uc-step-active>.uc-block-head{background:#f0fdf4}
.uc-card-section.uc-step-locked{opacity:.55}
.uc-required-missing input,.uc-required-missing select{border-color:#f59e0b !important;box-shadow:0 0 0 2px rgba(245,158,11,.12)}
.uc-card-section>.uc-block-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--bg);margin:0}
.uc-card-section>.uc-block-head .uc-block-title{font-weight:700;font-size:14px}
.uc-card-section>.uc-block-head .uc-block-subtitle{display:block;font-size:12px;color:var(--muted);line-height:1.45;margin-top:3px}
.uc-card-section>.field,.uc-card-section>.form-grid,.uc-card-section>.form-row,.uc-card-section>.uc-asset-compact-row{margin:12px 14px}
.uc-collapsed{background:#fff !important}
.uc-collapsed>.uc-block-head{margin-bottom:0}
.uc-collapsed>.uc-block-head .uc-block-subtitle{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:560px}
.uc-collapsed>*:not(.uc-block-head){display:none !important}
.uc-schedule-panel{padding:12px 14px}
.uc-schedule-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}
.uc-schedule-summary{font-size:13px;color:var(--muted);line-height:1.35;padding:9px 10px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;width:100%}
.uc-schedule-summary.ok{border-color:#86efac;background:#f0fdf4;color:#166534;font-weight:700}
.uc-schedule-summary.warn{border-color:#fcd34d;background:#fffbeb;color:#b45309;font-weight:700}
.uc-schedule-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-shrink:0;margin-top:10px}
.uc-schedule-series-panel{display:none;border:1px solid #dbe4f0;border-radius:8px;background:#fff;padding:10px;margin-top:8px}
.uc-schedule-series-panel.open{display:block}
.uc-series-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;align-items:end}
.uc-schedule-rows{display:flex;flex-direction:column;gap:8px}
.uc-schedule-row{position:relative;z-index:1;border:1px solid #e6edf5;border-radius:8px;background:#fff;overflow:hidden}
.uc-schedule-row:not(.collapsed){z-index:2}
.uc-schedule-row-summary{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;background:#fbfdff;color:#5f7896;font-size:13px;font-weight:700;cursor:pointer}
.uc-schedule-row-summary span,.uc-schedule-group-summary span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uc-schedule-summary-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.uc-schedule-row-fields{display:grid;grid-template-columns:150px 150px minmax(180px,1fr) 36px;gap:8px;align-items:end;padding:8px;border-top:1px solid #eef3f8}
.uc-schedule-row:not(.collapsed) .uc-schedule-row-summary{display:none}
.uc-schedule-row:not(.collapsed) .uc-schedule-row-fields{border-top:0}
.uc-schedule-row.collapsed .uc-schedule-row-fields{display:none}
.uc-schedule-row .field label{font-size:11px}
.uc-schedule-remove{height:36px;width:36px;padding:0 !important;color:var(--red);font-size:18px;line-height:1}
.uc-schedule-group{border:1px solid #dbe4f0;border-radius:8px;background:#fff;overflow:hidden}
.uc-schedule-group-summary{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;background:#fbfdff;color:#5f7896;font-size:13px;font-weight:700;cursor:pointer}
.uc-schedule-group .uc-schedule-row{border:0;border-top:1px solid #eef3f8;border-radius:0}
.uc-schedule-group.collapsed .uc-schedule-row{display:none}
.uc-schedule-totals{display:none}
.uc-schedule-totals b{display:block;font-size:14px;color:var(--text);margin-top:2px}
.uc-asset-compact-row{display:grid;grid-template-columns:1fr 1fr 1.45fr .95fr;gap:10px;align-items:end}
.uc-asset-compact-row .field{margin:0 !important}
#uc-object-block.uc-asset-block .uc-block-head{margin-bottom:0}
#m-accounting-card.uc-asset-mode .uc-progressive-head{display:none}
#m-accounting-card.uc-asset-mode .uc-upper-summary{display:none !important}
#m-accounting-card.uc-asset-mode #uc-object-block:not(.uc-asset-can-collapse) .uc-block-toggle,
#m-accounting-card.uc-asset-mode #uc-contract-block .uc-block-toggle{display:none}
#m-accounting-card.uc-asset-mode #uc-object-block{background:#fff !important}
#m-accounting-card.uc-asset-mode #uc-contract-block{background:var(--bg) !important}
#m-accounting-card.uc-schedule-editing .modal-foot{display:none}
@media(max-width:980px){.uc-asset-compact-row{grid-template-columns:1fr 1fr}.uc-asset-compact-row .field:nth-child(3){grid-column:1 / -1}}
.uc-preview{display:none;padding:9px 12px;border:1px solid #dbe4f0;border-radius:10px;background:#f8fafc;color:#31506f;font-size:12px;line-height:1.35}
.uc-preview b{display:block;color:var(--text);font-size:13px;margin-top:2px;overflow-wrap:anywhere}
.uc-price-mode{margin:0 0 2px;border:1px solid #e6edf5;border-radius:8px;background:#fbfdff;padding:10px}
.uc-price-mode-title{font-size:12px;font-weight:700;color:#5f7896;text-transform:uppercase;margin-bottom:8px}
.uc-price-mode-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.uc-price-option{min-height:66px;padding:9px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;text-align:left;cursor:pointer;font-family:inherit;color:var(--text);transition:border-color .15s,background .15s,box-shadow .15s}
.uc-price-option:hover{border-color:var(--green);background:var(--selected-bg)}
.uc-price-option.active{border-color:var(--green);background:var(--selected-bg);box-shadow:var(--selected-ring)}
.uc-price-option b{display:block;font-size:13px;line-height:1.2;margin-bottom:4px}
.uc-price-option span{display:block;font-size:11px;line-height:1.25;color:var(--muted)}
@media(max-width:980px){.uc-price-mode-options{grid-template-columns:1fr}}
.search-select{position:relative;width:100%;min-width:0}
.search-select-native{position:absolute !important;inset:0 !important;width:1px !important;height:1px !important;opacity:0 !important;pointer-events:none !important}
.search-select-input{width:100%;min-width:0;padding:9px 34px 9px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;background:#fff;color:var(--text)}
.search-select-input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-l)}
.search-select::after{content:'⌄';position:absolute;right:12px;top:50%;transform:translateY(-54%);color:var(--muted);font-size:15px;pointer-events:none}
.search-select-menu{display:none;position:absolute;z-index:250;left:0;right:0;top:calc(100% + 4px);max-height:240px;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-m);padding:4px}
.search-select.open .search-select-menu{display:block}
.search-select-menu.portal-open{display:block;position:fixed;z-index:10000;left:auto;right:auto;top:auto;box-shadow:0 14px 34px rgba(15,23,42,.18)}
.search-select-option{padding:8px 10px;border-radius:7px;cursor:pointer;font-size:13px;line-height:1.25}
.search-select-option:hover,.search-select-option.active{background:var(--green-bg);color:var(--green-d)}
.search-select-option.selected{font-weight:700;color:var(--green-d)}
.search-select-empty{padding:10px;color:var(--muted);font-size:12px;text-align:center}
.search-select-group{padding:8px 10px 4px;color:var(--muted);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.journal-filter-active{border-color:var(--green) !important;box-shadow:0 0 0 3px var(--green-l) !important}
.journal-filter-active + .search-select-input{border-color:var(--green) !important;box-shadow:0 0 0 3px var(--green-l) !important}
.journal-filter-toggle{padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--muted);font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.journal-filter-toggle:hover{border-color:var(--green);color:var(--green-d);background:var(--selected-bg)}
.journal-filter-toggle.active{background:var(--selected-bg);border-color:var(--green);color:var(--green-d);box-shadow:var(--selected-ring)}
.journal-filter-summary{font-size:12px;color:var(--muted)}
.table-filter-toggle{padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--muted);font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;box-shadow:0 0 0 3px transparent}
.table-filter-toggle:hover{border-color:var(--green);color:var(--green-d);background:var(--selected-bg)}
.table-filter-toggle.active{background:var(--selected-bg);border-color:var(--green);color:var(--green-d);box-shadow:var(--selected-ring)}
.table-filter-search{width:260px;max-width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:999px;font-size:12px;background:#fff;box-shadow:0 0 0 3px transparent}
.table-filter-search:focus{outline:none;border-color:var(--green);box-shadow:var(--selected-ring)}
.table-filter-search.table-filter-active{border-color:var(--green);box-shadow:var(--selected-ring);background:#fff}
.table-filter-result{font-size:12px;color:var(--muted)}
.table-filter-reset{justify-content:center;justify-self:end;width:104px;min-width:104px;height:34px;padding:6px 8px;border:1px solid transparent;font-size:12px;box-shadow:0 0 0 3px transparent;text-align:center}
.table-filter-reset.active{border-color:var(--green);color:var(--green-d);background:var(--selected-bg);box-shadow:var(--selected-ring)}
.table-filter-reset.inactive{visibility:hidden;pointer-events:none;border-color:transparent;background:transparent}
.table-filter-panel{display:flex;flex-wrap:wrap;gap:8px;padding-top:0;border-top:0;align-items:end}
.table-filter-field{display:flex;flex-direction:column;gap:4px;min-width:0}
.table-filter-panel .table-filter-field{flex:1 1 180px;min-width:150px}
.table-filter-panel .table-filter-field:has(.table-filter-date-range){flex:1.2 1 220px;min-width:210px}
.table-filter-field label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.02em}
.table-filter-field input,.table-filter-field select{box-sizing:border-box;width:100%;min-width:0;height:36px;padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:#fff;outline:none;box-shadow:0 0 0 3px transparent}
.table-filter-field input.table-filter-active,.table-filter-field select.table-filter-active,.table-filter-field.is-active input,.table-filter-field.is-active select{border-color:var(--green);box-shadow:var(--selected-ring);background:#fff}
.table-filter-field.is-active label{color:var(--green-d)}
.table-filter-date-range{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.search-select-suggestion{padding:9px 10px;border-top:1px solid var(--border);font-size:12px;line-height:1.35}
.search-select-suggestion:first-child{border-top:0}
.search-select-suggestion-title{font-weight:700;color:var(--text);overflow-wrap:anywhere}
.search-select-suggestion-meta{margin-top:2px;color:var(--muted)}
.search-select-suggestion .btn{margin-top:7px;min-height:30px;padding:5px 9px;font-size:12px}
.checkbox-list{border:1px solid var(--border);border-radius:10px;background:#fff;max-height:230px;overflow:auto;padding:6px;display:flex;flex-direction:column;gap:2px}
.checkbox-list:focus-within{border-color:var(--green);box-shadow:0 0 0 3px var(--green-l)}
.checkbox-row{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:8px;cursor:pointer;font-size:13px;line-height:1.25}
.checkbox-row:hover{background:var(--green-bg)}
.checkbox-row input{width:16px;height:16px;min-width:16px;accent-color:var(--green)}
.checkbox-row span{overflow-wrap:anywhere}
.checkbox-list-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.checkbox-list-actions .btn{padding:5px 9px;font-size:12px;min-height:30px}
.form-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}
.form-row-3{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1.2fr);gap:14px}
.form-row-full{display:grid;grid-template-columns:minmax(0,1fr);gap:14px}
.op-meta-row{display:grid;grid-template-columns:180px minmax(0,1fr);gap:12px;align-items:end}
.op-meta-row.op-meta-date-only{grid-template-columns:180px minmax(0,1fr)}
.op-head-row{display:flex;align-items:center;justify-content:flex-start;gap:16px;flex-wrap:wrap}
.op-kind-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;width:100%;min-width:0;max-width:none;grid-column:1 / -1}
.op-kind-btn{min-width:0;justify-content:flex-start;align-items:flex-start;flex-direction:column;text-align:left;padding:10px 12px;border-radius:10px;font-size:12px;font-weight:600;box-shadow:none;white-space:normal;min-height:74px;line-height:1.2;background:#fff;color:var(--text);border-color:var(--border);transition:background .15s,border-color .15s,box-shadow .15s,color .15s,opacity .15s,filter .15s}
.op-kind-row.has-active .op-kind-btn:not(.active){opacity:1;filter:none;background:#fff;color:var(--text);border-color:var(--border);box-shadow:none}
.op-kind-row.has-active .op-kind-btn:not(.active):hover{background:var(--selected-bg);border-color:var(--green)}
.op-kind-btn.active{font-weight:700}
.op-kind-btn.btn-income.active,.op-kind-btn.btn-expense.active,.op-kind-btn.btn-transfer.active{background:var(--selected-bg);color:var(--text);border-color:var(--green);box-shadow:var(--selected-ring)}
.op-kind-btn b{display:block;font-size:14px;line-height:1.15;margin-bottom:5px;color:inherit}
.op-kind-btn span{display:block;font-size:11px;line-height:1.25;color:#607894;font-weight:500}
.op-kind-btn.active span{color:var(--muted);opacity:1}
.op-kind-row.op-kind-collapsed{display:flex;grid-column:1 / -1;align-items:center;justify-content:flex-start}
.op-kind-row.op-kind-collapsed .op-kind-btn:not(.active){display:none}
.op-kind-row.op-kind-collapsed .op-kind-btn.active{min-height:34px;width:auto;min-width:150px;padding:6px 12px;border-radius:10px;flex-direction:row;align-items:center;gap:8px}
.op-kind-row.op-kind-collapsed .op-kind-btn.active b{font-size:13px;margin:0}
.op-kind-row.op-kind-collapsed .op-kind-btn.active span{display:none}
.op-kind-row.op-kind-collapsed .op-kind-btn.active::after{content:'изменить';font-size:11px;color:var(--muted);font-weight:600}
.op-banner{padding:8px 12px;background:#f8fafc;border:1px solid #dbe4f0;border-radius:10px;font-size:12px;line-height:1.4;color:#6c7f9e;display:flex;align-items:center;min-height:58px;height:58px;overflow:hidden}
.op-party-suggestion{display:none;padding:9px 12px;background:var(--green-l);border:1px solid #86efac;border-radius:10px;color:var(--green-d);font-size:12px;line-height:1.4;align-items:center;justify-content:space-between;gap:10px}
.op-party-suggestion .btn{min-height:30px;padding:5px 9px;font-size:12px;white-space:nowrap}
.op-form-divider{height:1px;background:#dbe4f0;margin:2px 0 8px}
.op-stable-field{min-height:58px}
.op-stable-hidden{visibility:hidden;pointer-events:none}
.modal.op-modal{max-width:760px;border-radius:18px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(203,217,232,.95);box-shadow:0 22px 60px rgba(15,23,42,.22)}
.op-modal .modal-head{padding:14px 18px;flex-shrink:0;background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)}
.op-modal .modal-body{padding:14px 18px 0;overflow-y:auto;min-height:0;flex:1;background:#fbfdff}
.op-modal .modal-foot{padding:10px 18px 12px;background:#f8fafc;border-top:1px solid #e6edf5;flex-shrink:0}
.op-modal-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;width:100%}
.op-modal-title{font-size:17px;font-weight:800;line-height:1.15;white-space:nowrap;margin:0;color:#101828}
.op-header-field{display:flex;align-items:center;min-width:0;position:relative}
.op-header-field label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.op-header-field input,.op-header-field select{height:36px;min-height:36px;border-radius:10px;border:1px solid #dbe4f0;padding:6px 12px;font-size:13px;background:#fff;color:var(--text);width:100%;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.op-header-field input{width:148px;font-weight:700;font-variant-numeric:tabular-nums}
.op-header-field select{width:184px;font-weight:800}
.op-header-field input:hover,.op-header-field select:hover{border-color:#cbd9e8;background:#fbfdff}
.op-header-field input:focus,.op-header-field select:focus{outline:none;border-color:#9fc3e8;box-shadow:0 0 0 3px rgba(49,126,186,.12)}
.op-flow-native,.op-modal-head .search-select:has(#op-flow-type){display:none}
.op-modal-actions{display:flex;justify-content:flex-end;gap:6px;min-width:0}
.op-modal .field{gap:4px}
.op-modal .field label{font-size:11.5px;margin-bottom:1px;color:var(--muted)}
.op-modal #op-item,.op-modal #op-amount,.op-modal #op-qty,.op-modal #op-unit,.op-modal #op-note,.op-modal #op-date,.op-modal #op-article,.op-modal #op-money-from,.op-modal #op-money-to,.op-modal #op-offset-receivable,.op-modal #op-offset-payable,.op-modal #op-offset-amount,.op-modal #op-offset-external-note,.op-modal #op-offset-note{min-height:34px;border-radius:8px;border-color:#dbe4f0;font-size:13px;padding:5px 10px}
.op-modal #op-note{min-height:54px;padding-top:6px;padding-bottom:6px}
.op-modal .modal-close{width:32px;height:32px;border-radius:10px;font-size:20px;color:#7187a4;display:flex;align-items:center;justify-content:center;grid-column:2;grid-row:1;justify-self:end}
.op-modal .modal-close:hover{background:#eef4fb;color:#31506f}
.op-modal .modal-foot .btn{min-height:34px;padding:0 14px;border-radius:8px;font-size:13px;font-weight:700}
.op-modal .form-grid{gap:10px !important}
.op-main-details{border:1px solid #e6edf5;border-radius:14px;background:#fff;overflow:hidden;box-shadow:0 4px 14px rgba(15,23,42,.035)}
.op-main-details > summary{display:none;list-style:none;cursor:pointer;padding:8px 12px;background:#fff;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid #eef3f8}
.op-main-details.op-has-article > summary{display:flex}
.op-main-details > summary::-webkit-details-marker{display:none}
.op-main-summary-wrap{display:flex;align-items:center;gap:8px;min-width:0}
.op-main-summary{font-weight:700;color:#5f7896;font-size:12.5px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.op-main-toggle{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;border:1px solid #e6edf5;border-radius:8px;background:#fbfdff;color:#5f7896;font-size:12px;font-weight:700;padding:5px 9px;line-height:1}
.op-main-toggle::before{content:'▾';font-size:10px;color:#8aa0b8;transition:transform .15s}
.op-main-toggle::after{content:'Свернуть'}
.op-main-details:not([open]) .op-main-toggle::before{transform:rotate(-90deg)}
.op-main-details:not([open]) .op-main-toggle::after{content:'Развернуть'}
.op-main-details:not([open]) > summary{border-bottom:0}
.op-main-details .form-grid{padding:14px}
.op-main-details.op-start-mode{display:none}
.op-main-details.op-upper-collapsed > summary{display:flex}
.op-main-details.op-upper-collapsed .op-main-toggle::before{transform:rotate(-90deg)}
.op-main-details.op-upper-collapsed .op-main-toggle::after{content:'Показать'}
.op-main-details.op-upper-collapsed .form-row-full,
.op-main-details.op-upper-collapsed .op-meta-row,
.op-main-details.op-upper-collapsed .op-money-row,
.op-main-details.op-upper-collapsed #op-offset-section,
.op-main-details.op-upper-collapsed #op-counterparty-article-suggestion,
.op-main-details.op-upper-collapsed #op-form-divider{display:none !important}
.op-main-details.op-lower-pending #op-contract-payment-section,
.op-main-details.op-lower-pending #op-partner-tax-field,
.op-main-details.op-lower-pending #op-items-section,
.op-main-details.op-lower-pending #op-lower-step-head,
.op-main-details.op-lower-pending #op-item-field,
.op-main-details.op-lower-pending #op-amount-row,
.op-main-details.op-lower-pending #op-asset-obligation-field,
.op-main-details.op-lower-pending #op-note-field,
#op-form.op-lower-pending #op-alloc-section{display:none !important}
.op-lower-step-head{border:1px solid var(--border);border-radius:8px;background:var(--bg);padding:12px 14px;margin-bottom:0}
.op-lower-step-title{font-weight:700;font-size:14px;color:var(--text)}
.op-lower-step-hint{font-size:12px;color:var(--muted);line-height:1.45;margin-top:2px}
.op-money-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}
.op-amount-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}
.op-offset-mode{border:1px solid #dbe4f0;border-radius:8px;background:#fff;overflow:hidden}
.op-offset-tabs{display:flex;gap:6px;padding:8px;background:#f8fafc;border-bottom:1px solid #e6edf5}
.op-offset-tab{min-height:32px;border:1px solid #dbe4f0;background:#fff;color:#31506f;border-radius:8px;padding:0 12px;font-size:12.5px;font-weight:800;cursor:pointer}
.op-offset-tab.active{background:#eaf7ef;border-color:#87d6a1;color:#146c38}
.op-offset-form{padding:12px;display:flex;flex-direction:column;gap:10px}
.op-offset-source-tabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.op-offset-source-tabs label{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:5px 10px;border:1px solid #dbe4f0;border-radius:8px;background:#f8fafc;color:#31506f;font-size:12px;font-weight:800}
.op-offset-source-tabs input{width:auto;margin:0}
.op-offset-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}
.op-offset-summary{padding:9px 11px;border:1px solid #dbe4f0;border-radius:8px;background:#f8fafc;color:#5f7896;font-size:12px;line-height:1.4}
.op-amount-grid.op-amount-single{grid-template-columns:minmax(0,1fr)}
.op-qty-inner{display:grid;grid-template-columns:minmax(0,1.25fr) 120px;gap:6px}
.op-items-toggle{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#fff;border:1px solid var(--border);border-radius:8px}
.op-items-toggle input{width:auto;margin-top:2px}
.op-items-section{border:1px solid var(--border);border-radius:8px;background:#fff;overflow:hidden}
.op-items-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--bg)}
.op-items-title{font-weight:700;font-size:14px}
.op-items-hint{font-size:12px;color:var(--muted);line-height:1.45}
.op-items-bulk-tools{display:flex;flex-direction:column;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);background:#fbfdff}
.op-items-bulk-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:10px;align-items:end}
.op-items-bulk-field{display:flex;flex-direction:column;gap:4px;min-width:0}
.op-items-bulk-field>span{font-size:12px;font-weight:800;color:#31506f;white-space:nowrap}
.op-items-bulk-field select{box-sizing:border-box;min-width:0;width:100%;min-height:36px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;padding:6px 10px;font-size:13px}
.op-items-bulk-prorata-btn{align-self:end;white-space:nowrap;min-height:36px}
.op-items-bulk-prorata-form{display:none;flex-direction:column;gap:8px;padding:10px;background:#f5fbff;border:1px solid #cfe1ef;border-radius:8px}
.op-items-bulk-prorata-form.open{display:flex}
.op-items-bulk-prorata-head{font-size:12px;font-weight:700;color:#244967;line-height:1.4}
.op-items-bulk-prorata-rows{display:flex;flex-direction:column;gap:6px}
.op-items-bulk-prorata-row{display:grid;grid-template-columns:minmax(0,1fr) 110px 28px;gap:8px;align-items:center}
.op-items-bulk-prorata-row select{box-sizing:border-box;min-width:0;width:100%;min-height:34px;border-radius:8px;border:1px solid #dbe4f0;padding:5px 10px;font-size:13px;background:#fff}
.op-items-bulk-prorata-pct{display:flex;align-items:center;gap:4px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;padding:2px 8px;min-height:34px}
.op-items-bulk-prorata-pct input{width:100%;border:0;outline:0;font-size:13px;font-variant-numeric:tabular-nums;text-align:right;background:transparent;padding:4px 0}
.op-items-bulk-prorata-pct span{font-size:12px;color:var(--muted);font-weight:700}
.op-items-bulk-prorata-remove{padding:6px 8px;color:var(--red)}
.op-items-bulk-prorata-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.op-items-bulk-prorata-summary{margin-right:auto;font-size:12px;font-weight:700;color:var(--muted);font-variant-numeric:tabular-nums}
.op-items-bulk-prorata-summary.ok{color:var(--green-d)}
.op-items-bulk-prorata-summary.bad{color:var(--red)}
.op-items-bulk-prorata-tools button[data-apply][disabled]{opacity:.5;cursor:not-allowed}
.alloc-list-head-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.op-line-quick-split{margin:6px 0 8px;padding:10px;background:#fff;border:1px solid #cfe1ef;border-radius:8px;display:flex;flex-direction:column;gap:8px}
.op-line-quick-split-head{font-size:12px;font-weight:700;color:#244967;line-height:1.4}
.op-line-quick-split-rows{display:flex;flex-direction:column;gap:6px}
.op-line-quick-split-row{display:grid;grid-template-columns:minmax(0,1fr) 140px 28px;gap:8px;align-items:center}
.op-line-quick-split-row select{box-sizing:border-box;min-width:0;width:100%;min-height:34px;border-radius:8px;border:1px solid #dbe4f0;padding:5px 10px;font-size:13px;background:#fff}
.op-line-quick-split-qty{display:flex;align-items:center;gap:4px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;padding:2px 8px;min-height:34px}
.op-line-quick-split-qty input{width:100%;border:0;outline:0;font-size:13px;font-variant-numeric:tabular-nums;text-align:right;background:transparent;padding:4px 0}
.op-line-quick-split-qty span{font-size:11px;color:var(--muted);font-weight:700;white-space:nowrap}
.op-line-quick-split-remove{padding:6px 8px;color:var(--red)}
.op-line-quick-split-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.op-line-quick-split-summary{margin-right:auto;font-size:12px;font-weight:700;color:var(--muted);font-variant-numeric:tabular-nums}
.op-line-quick-split-summary.ok{color:var(--green-d)}
.op-line-quick-split-summary.bad{color:var(--red)}
.op-line-quick-split-tools button[data-apply][disabled]{opacity:.5;cursor:not-allowed}
.op-items-list{display:flex;flex-direction:column}
.op-item-line{display:grid;grid-template-columns:30px minmax(220px,1fr) 126px 72px 50px 86px 96px 30px;gap:6px;align-items:end;padding:10px 10px;border-bottom:1px solid var(--border);cursor:pointer}
.op-item-line.op-item-line-locked{grid-template-columns:30px minmax(0,1fr) 128px 44px;align-items:center}
.op-item-line:last-child{border-bottom:0}
.op-item-line:hover{background:#f8fafc}
.op-items-list.op-items-has-open .op-item-line{opacity:.45}
.op-items-list.op-items-has-open .op-item-line.op-item-line-alloc-open{opacity:1;background:#eef6ff;box-shadow:inset 4px 0 var(--green)}
.op-items-list.op-items-has-open .op-item-line.op-item-line-alloc-open:hover{background:#eaf4ff}
.op-item-line.op-item-line-alloc-open{padding-left:14px}
.op-item-line label{display:block;font-size:11px;color:var(--muted);font-weight:600;margin-bottom:4px}
.op-item-line > div{min-width:0}
.op-item-line input,.op-item-line select{box-sizing:border-box;min-width:0;width:100%;height:36px;padding:5px 8px;font-size:13px}
.op-line-index{align-self:center;justify-self:center;color:#94a3b8;font-size:11px;font-weight:700}
.op-line-name-cell input{font-weight:600}
.op-line-doc-meta{font-size:12px;color:var(--muted);margin-top:3px}
.op-line-doc-main{min-width:0;padding:2px 0}
.op-line-doc-label{font-size:11px;color:var(--muted);font-weight:700;margin-bottom:3px}
.op-line-doc-title{font-size:14px;line-height:1.28;font-weight:800;color:var(--text);white-space:normal;overflow:visible}
.op-line-doc-qty{align-self:stretch;display:flex;flex-direction:column;justify-content:center;gap:3px;padding:7px 10px;border:1px solid #dbe4f0;border-radius:8px;background:#fff}
.op-line-doc-qty span{font-size:11px;color:var(--muted);font-weight:700}
.op-line-doc-qty b{font-size:15px;line-height:1.1;white-space:nowrap;color:var(--text)}
.op-item-line .op-line-remove{justify-self:end;padding:6px 8px;color:var(--red)}
.op-line-lock{align-self:center;justify-self:center;font-size:10px;font-weight:800;color:#64748b;background:#eef2f7;border:1px solid #dbe4f0;border-radius:999px;padding:4px 6px}
.op-line-alloc-toggle-row{grid-column:1 / -1;display:flex;align-items:center;justify-content:flex-start;margin-top:0;margin-bottom:-1px}
.op-line-alloc-toggle{box-sizing:border-box;max-width:100%;min-height:28px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:800;color:#31506f;background:#f8fafc;border:1px solid #dbe4f0;white-space:normal;text-align:left}
.op-line-alloc-toggle:hover{background:#edf4fb;border-color:#cbd9e8}
.op-line-alloc-toggle.complete{color:var(--green-d);background:var(--green-l);border-color:#c8f0da}
.op-line-alloc-toggle.partial{color:#9a6400;background:var(--amber-l);border-color:#fde3a3}
.op-line-alloc-toggle.over{color:var(--red);background:var(--red-l);border-color:#ffc9c9}
.op-line-alloc-toggle.open{position:relative;border-color:#b8d7ee;background:#eef6ff;color:#31506f;border-bottom-color:#eef6ff;border-radius:8px 8px 0 0;box-shadow:0 -1px 0 #b8d7ee inset;font-size:11px;font-weight:700}
.op-item-line-alloc-open .op-line-alloc-toggle-row{margin-top:2px}
.op-item-line-alloc-open .op-line-alloc-toggle-row{display:none}
.op-line-alloc-panel{grid-column:1 / -1;display:none;background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:10px}
.op-line-alloc-panel.open{display:block}
.op-item-line-alloc-open .op-line-alloc-panel{border-color:#b8d7ee;border-left:4px solid var(--green);border-radius:0 8px 8px 8px;background:#f8fbff;box-shadow:0 1px 0 rgba(15,23,42,.03)}
.op-line-alloc-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.op-line-allocs{display:flex;flex-direction:column;gap:6px}
.op-line-alloc-row{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1.15fr) minmax(0,1fr) minmax(104px,.7fr) minmax(104px,.75fr) 32px;gap:8px;align-items:center;background:#fff;border:1px solid #dbe4f0;border-radius:8px;padding:8px}
.op-line-alloc-row .op-line-alloc-remove{align-self:center;justify-self:end}
.op-line-alloc-row select,.op-line-alloc-row input{min-width:0;width:100%;height:36px;border-radius:8px;border:1px solid #dbe4f0;padding:6px 10px;font-size:13px;background:#fff}
.op-line-alloc-row select,.op-line-alloc-row input{box-sizing:border-box}
.op-line-alloc-summary{margin-top:8px;font-size:12px;color:var(--muted)}
.op-items-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:10px 14px;background:var(--bg);border-top:1px solid var(--border);font-size:12px}
.op-items-summary b{display:block;font-size:14px;color:var(--text);margin-top:2px}
.journal-table{table-layout:fixed;width:100%;min-width:1080px}
.journal-table th,.journal-table td{vertical-align:top;overflow:hidden}
.journal-table th{font-size:10px;line-height:1.1;padding:9px 10px}
.journal-table td{font-size:12px;line-height:1.25;padding:10px 10px}
.journal-table tbody tr.journal-row{cursor:pointer;height:58px}
.journal-table tbody tr.journal-row > td{height:58px;max-height:58px;overflow:hidden}
.journal-table tbody tr.journal-row:hover{background:#f8fafc}
.journal-table.journal-has-open tbody tr.journal-row{opacity:.45}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open{opacity:1;background:#eef6ff;box-shadow:inset 4px 0 var(--green)}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open:hover{background:#eaf4ff}
.journal-table tbody tr.journal-row:hover td:last-child{background:#f8fafc}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open td:last-child{background:#eef6ff}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open:hover td:last-child{background:#eaf4ff}
.journal-table .journal-id{color:#31506f;white-space:nowrap}
.journal-table .journal-date{font-weight:800;color:#12304f;line-height:1.1}
.journal-table .journal-op-number{display:block;margin-top:4px;font-size:11px;line-height:1;font-weight:500;color:#94a3b8;letter-spacing:0}
.journal-table .journal-row-open .journal-op-number{display:block}
.journal-table .journal-content{min-width:0;max-width:100%}
.journal-table tbody tr.journal-row td:nth-child(2)>*,
.journal-table tbody tr.journal-row td:nth-child(4)>*{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis}
.journal-table .journal-main-text{font-weight:600;color:var(--text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.journal-table .journal-sub-text{font-size:11px;color:var(--muted);line-height:1.2;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.journal-table .journal-sub-text.journal-sub-warning{color:var(--red)}
.journal-table .journal-objects{font-size:11px;color:#31506f;line-height:1.2}
.journal-object-line{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.journal-object-summary{display:inline-flex;align-items:baseline;gap:4px;min-width:0;max-width:100%;vertical-align:bottom}
.journal-object-first{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.journal-object-more{flex:0 0 auto;white-space:nowrap}
.journal-table td:nth-child(2){word-break:normal}
.journal-table td.num{white-space:nowrap}
.journal-amount{font-weight:500;color:var(--text)}
.journal-amount-income{color:var(--green-d)}
.journal-amount-expense{color:var(--text)}
.journal-cell-main{font-weight:600;color:var(--text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.journal-status-line{margin-top:3px;line-height:1.1;white-space:nowrap}
.journal-status-dot{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;font-size:11px;font-weight:800;line-height:1}
.journal-status-dot.ok{background:var(--green-l);color:var(--green-d)}
.journal-status-dot.warn{background:var(--amber-l);color:var(--amber)}
.journal-status-dot.bad{background:var(--red-l);color:var(--red)}
.journal-status-dot.gray{background:#eef2f7;color:#64748b}
.journal-col-id{width:96px}
.journal-col-counterparty{width:190px}
.journal-col-article{width:142px}
.journal-article-cell{min-width:0}
.journal-article-cell .journal-cell-main{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.journal-col-content{width:auto}
.journal-col-qty{width:76px}
.journal-col-amount{width:118px}
.journal-col-objects{width:168px}
.journal-table th:nth-child(5),.journal-table td:nth-child(5),
.journal-table th:nth-child(6),.journal-table td:nth-child(6),
.journal-table th:nth-child(7),.journal-table td:nth-child(7){white-space:nowrap;overflow:visible}
.journal-table th:nth-child(2),.journal-table td:nth-child(2),
.journal-table th:nth-child(3),.journal-table td:nth-child(3),
.journal-table th:nth-child(4),.journal-table td:nth-child(4){min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:normal}
.journal-table td:nth-child(7) .badge{display:inline-flex;max-width:none}
.journal-table .journal-detail-row > td{background:#f8fafc;border-top:0;padding:0 16px 14px;box-shadow:inset 4px 0 var(--green)}
.finance-obligations-wrap{margin-bottom:14px}
.finance-obligations-toolbar{display:grid;grid-template-columns:minmax(max-content,auto) max-content minmax(260px,390px) minmax(170px,1fr) 120px;align-items:center;column-gap:12px}
.finance-obligations-toolbar .table-filter-result{justify-self:end;min-width:170px;text-align:right;white-space:nowrap}
.finance-obligation-filter-panel{display:flex;flex-wrap:wrap;gap:8px;align-items:end}
.finance-obligation-filter-panel .table-filter-field{gap:3px;min-width:0}
.finance-obligation-filter-panel .finance-filter-period{flex:.8 1 230px;min-width:222px}
.finance-obligation-filter-panel .finance-filter-partner{flex:1.25 1 180px;min-width:165px}
.finance-obligation-filter-panel .finance-filter-counterparty{flex:1.25 1 190px;min-width:175px}
.finance-obligation-filter-panel .finance-filter-direction{flex:.75 1 115px;min-width:105px}
.finance-obligation-filter-panel .finance-filter-type{flex:.75 1 115px;min-width:105px}
.finance-obligation-filter-panel .finance-filter-status{flex:.6 1 95px;min-width:90px}
.finance-obligation-filter-panel .table-filter-field label{font-size:10px}
.finance-obligation-filter-panel .table-filter-field input,
.finance-obligation-filter-panel .table-filter-field select{box-sizing:border-box;width:100%;height:36px;padding:6px 8px;font-size:12px;outline:none;box-shadow:0 0 0 3px transparent}
.finance-obligation-filter-panel .table-filter-field input.table-filter-active,
.finance-obligation-filter-panel .table-filter-field select.table-filter-active,
.finance-obligation-filter-panel .table-filter-field.is-active input,
.finance-obligation-filter-panel .table-filter-field.is-active select{border-color:var(--green)!important;box-shadow:var(--selected-ring)!important;background:#fff!important}
.finance-obligation-filter-panel .table-filter-field.is-active label{color:var(--green-d)}
.finance-obligation-filter-panel .table-filter-date-range{gap:4px}
.finance-obligation-filter-panel .table-filter-date-range input{width:100%;min-width:0}
.finance-obligation-filter-panel .table-filter-field input.search-select-input{height:36px;min-height:36px;padding:6px 30px 6px 8px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.finance-obligation-filter-panel .search-select::after{right:9px}
.finance-obligation-total-row{display:grid;grid-template-columns:minmax(220px,1fr) 210px 210px 230px;align-items:center;column-gap:10px;font-size:12px;color:var(--muted)}
.finance-total-item{display:inline-flex;align-items:baseline;justify-content:flex-end;gap:5px;min-width:0;white-space:nowrap;font-weight:700}
.finance-total-item b{font-size:12px;font-weight:800}
.finance-total-we-owe{color:var(--red)}
.finance-total-owed-to-us{color:var(--green-d)}
.finance-total-balance{display:inline-flex;align-items:baseline;justify-content:center;gap:7px;min-width:0;padding:6px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font-weight:800;white-space:nowrap}
.finance-total-balance b{font-size:15px;font-weight:900}
.finance-total-balance.finance-direction-we-owe{border-color:#fecaca;background:#fff5f5;color:var(--red)}
.finance-total-balance.finance-direction-owed-to-us{border-color:#bbf7d0;background:#f0fdf4;color:var(--green-d)}
.finance-total-caption{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700;color:var(--text)}
.finance-reconciliation-box{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 14px;border-top:1px solid var(--border);background:#fbfdff;font-size:12px;color:var(--muted)}
.finance-reconciliation-box>div{display:flex;flex-direction:column;gap:2px;min-width:0}
.finance-reconciliation-box b{color:var(--text);font-size:13px;line-height:1.2}
.finance-reconciliation-box span:not(.badge){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.finance-reconciliation-box .btn{height:30px;padding:5px 12px;font-size:12px;white-space:nowrap}
.finance-reconciliation-box.is-muted{background:#f8fafc}
.finance-reconciliation-box.is-locked{background:#f0fdf4;border-color:#bbf7d0}
.finance-reconciliation-box.is-locked b{color:var(--green-d)}
.finance-reconciliation-box.is-drift{background:#fffbeb;border-color:#fde68a}
.finance-reconciliation-box.is-drift b{color:#b45309}
.finance-reconciliation-history{border-top:1px solid var(--border);background:#fff;padding:8px 14px 10px}
.finance-reconciliation-history-head{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:30px}
.finance-reconciliation-history-head b{font-size:13px;color:var(--text)}
.finance-reconciliation-history-head .btn{height:28px;padding:4px 10px;font-size:12px}
.finance-reconciliation-history-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:8px;margin-top:6px}
.finance-reconciliation-history-item{display:grid;grid-template-columns:minmax(0,1fr) max-content;align-items:center;gap:10px;min-height:44px;padding:8px 10px;border:1px solid #dbe6f2;border-radius:8px;background:#f8fbff;color:var(--text);cursor:pointer;text-align:left}
.finance-reconciliation-history-item:hover{border-color:#86efac;background:#f0fdf4}
.finance-reconciliation-history-item span{min-width:0}
.finance-reconciliation-history-item b{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}
.finance-reconciliation-history-item small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:12px;margin-top:2px}
.finance-reconciliation-history-item>span:last-child{font-weight:800;white-space:nowrap;font-size:13px}
.finance-reconciliation-history-empty{padding:8px 0;color:var(--muted);font-size:13px}
.finance-filter-reset{justify-content:center;justify-self:end;width:104px;min-width:104px;height:34px;padding:6px 8px;border:1px solid transparent;font-size:12px;box-shadow:0 0 0 3px transparent;text-align:center}
.finance-filter-reset.active{border-color:var(--green);color:var(--green-d);background:var(--selected-bg);box-shadow:var(--selected-ring)}
.finance-filter-reset.inactive{visibility:hidden;pointer-events:none;border-color:transparent;background:transparent}
.finance-ledger-table{table-layout:fixed;width:100%;min-width:100%}
.finance-ledger-table th,.finance-ledger-table td{vertical-align:top;overflow:hidden}
.finance-ledger-table th{font-size:10px;line-height:1.1;padding:7px 8px}
.finance-ledger-table td{font-size:12px;line-height:1.22;padding:7px 8px}
.finance-ledger-table tbody tr.finance-ledger-row{height:54px}
.finance-ledger-table tbody tr.finance-ledger-row > td{height:54px;max-height:54px;overflow:hidden}
.finance-ledger-table tbody tr.finance-ledger-row.finance-row-clickable{cursor:pointer}
.finance-ledger-table tbody tr.finance-ledger-row:hover{background:#f8fafc}
.finance-ledger-table tbody tr.finance-ledger-row:hover td:last-child{background:#f8fafc}
.finance-ledger-table tbody tr.finance-ledger-row.finance-row-open > td{border-bottom-color:#dbe4f0}
.finance-cell{min-width:0;max-width:100%;display:block}
.finance-cell-main{font-weight:600;color:var(--text);line-height:1.16;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.finance-cell-sub{font-size:11px;color:var(--muted);line-height:1.14;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.finance-date-cell .finance-cell-main{font-weight:800;color:#12304f}
.finance-date-cell .finance-cell-sub{font-weight:500;color:#94a3b8}
.finance-date-action{display:inline-flex;align-items:center;max-width:100%;margin-top:2px;padding:0;border:0;background:transparent;color:#94a3b8;font:inherit;font-size:10.5px;font-weight:600;line-height:1.1;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.finance-date-action:hover{color:#2563eb;text-decoration:underline;text-underline-offset:2px}
.finance-date-action:focus-visible{outline:2px solid rgba(37,99,235,.28);outline-offset:2px;border-radius:4px}
.finance-cell-money .finance-cell-main{font-weight:500}
.finance-cell-badge-line{display:flex;justify-content:flex-end;align-items:center;margin-top:2px;min-height:18px;overflow:visible;text-overflow:clip}
.finance-cell-badge-line .badge{max-width:100%;overflow:hidden;text-overflow:ellipsis}
.finance-money-warn .finance-cell-main{color:var(--amber)}
.finance-direction-we-owe.finance-cell-sub,.finance-cell-money.finance-direction-we-owe .finance-cell-main{color:var(--red)}
.finance-direction-owed-to-us.finance-cell-sub,.finance-cell-money.finance-direction-owed-to-us .finance-cell-main{color:var(--green-d)}
.finance-status-cell{display:flex;align-items:center;justify-content:flex-start;gap:6px;min-width:0;max-width:100%;flex-wrap:nowrap}
.finance-status-badges{display:inline-flex;align-items:center;gap:6px;min-width:0;max-width:100%;flex:0 0 auto}
.finance-status-badges .badge{max-width:100%;overflow:hidden;text-overflow:ellipsis}
.finance-row-action{flex:0 0 auto;align-self:center;padding:2px 4px;font-size:12px;line-height:1.1;opacity:.88;white-space:nowrap}
.finance-ledger-subrow td{background:#f8fafc;color:var(--muted);font-size:12px;padding-top:0;border-top:0}
.finance-ledger-detail-row>td{background:#f8fafc;border-top:0;padding:0 14px 14px;box-shadow:inset 4px 0 var(--green);overflow:visible}
.finance-ledger-detail-panel{display:flex;flex-direction:column;gap:12px;align-items:flex-start;border:1px solid #dbe4f0;border-top:0;border-radius:0 0 10px 10px;background:#fff;padding:14px 16px;margin-top:0}
.finance-ledger-detail-copy{min-width:0}
.finance-ledger-detail-copy b{display:block;font-size:13px;line-height:1.25;color:var(--text);margin-bottom:4px}
.finance-ledger-detail-copy span{display:block;font-size:13px;line-height:1.45;color:#475569;white-space:normal;overflow-wrap:anywhere}
.finance-ledger-detail-actions{display:flex;gap:8px;align-items:center;justify-content:flex-start;flex-wrap:wrap}
.finance-readable-detail{gap:14px;padding:14px 16px}
.finance-readable-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;width:100%}
.finance-readable-detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;width:100%}
.finance-readable-field{min-width:0;border:1px solid #edf2f7;border-radius:8px;background:#f8fafc;padding:8px 10px}
.finance-readable-field.wide{grid-column:span 2}
.finance-readable-field span{display:block;color:var(--muted);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.02em;line-height:1.15;margin-bottom:3px}
.finance-readable-field b{display:block;color:var(--text);font-size:13px;font-weight:700;line-height:1.3;white-space:normal;overflow-wrap:anywhere}
.finance-readable-field.finance-direction-we-owe b{color:var(--red)}
.finance-readable-field.finance-direction-owed-to-us b{color:var(--green-d)}
@media(max-width:980px){.finance-readable-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.finance-readable-detail-head{flex-direction:column}.finance-readable-detail-grid{grid-template-columns:1fr}.finance-readable-field.wide{grid-column:auto}}
.finance-col-date{width:9%}
.finance-col-party{width:18%}
.finance-col-content{width:19%}
.finance-col-object{width:180px}
.finance-col-period{width:17%}
.finance-col-money{width:10.5%}
.finance-col-status{width:16%}
.finance-ledger-table th:nth-child(2),.finance-ledger-table td:nth-child(2),
.finance-ledger-table th:nth-child(3),.finance-ledger-table td:nth-child(3),
.finance-ledger-table th:nth-child(4),.finance-ledger-table td:nth-child(4){min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:normal}
.finance-ledger-table td.num,.finance-ledger-table th.num{white-space:nowrap;text-align:right}
.journal-detail-card{border:1px solid #dbe4f0;border-top:0;border-radius:0 0 10px 10px;background:#fff;padding:14px 16px 12px;margin-top:0}
.journal-detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}
.journal-detail-field{background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;padding:8px 10px}
.journal-detail-field span{display:block;font-size:11px;color:var(--muted);margin-bottom:3px}
.journal-detail-field b{display:block;font-size:13px;color:var(--text);font-weight:700;line-height:1.25}
.journal-detail-section{margin-top:12px}
.journal-detail-section:first-child{margin-top:0}
.journal-detail-row>td{width:100%;overflow:visible!important;box-sizing:border-box}
.journal-detail-row [id^="journal-detail-host-"]{width:100%;max-width:none}
.journal-detail-row .journal-detail-card,.journal-detail-row .journal-detail-section{width:100%;max-width:none;min-width:0;box-sizing:border-box}
.journal-detail-section h4{font-size:13px;font-weight:700;margin-bottom:6px}
.journal-detail-note{font-size:13px;line-height:1.45;white-space:pre-wrap;color:var(--text)}
.journal-detail-muted{font-size:13px;color:var(--muted);line-height:1.45}
.journal-source-link{border:0;background:transparent;color:#2563eb;text-decoration:underline;cursor:pointer;font:inherit;padding:0}
.journal-source-note{margin-top:6px;padding:8px 10px;border:1px solid #e6edf5;border-radius:8px;background:#f8fafc;white-space:normal}
.journal-detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.journal-mini-table{width:100%;border-collapse:collapse;font-size:13px}
.journal-mini-table th,.journal-mini-table td{padding:5px 8px;border-bottom:1px solid #edf2f7;text-align:left}
.journal-mini-table th{font-size:11px;color:var(--muted);font-weight:700;background:#f8fafc}
.journal-mini-table td.num,.journal-mini-table th.num{text-align:right}
.journal-mini-table .journal-section-row td{background:#f8fafc;color:#334155;font-size:12px;padding-top:4px;padding-bottom:4px;line-height:1.15}
.journal-mini-table .journal-section-row .journal-section-name{font-weight:700}
.journal-detail-row .journal-invoice-items-table,.journal-detail-row .journal-invoice-group-table{table-layout:fixed;width:100%!important;min-width:100%!important;max-width:none!important}
.journal-invoice-items-table th,.journal-invoice-items-table td{overflow:hidden}
.journal-invoice-items-table th:nth-child(1),.journal-invoice-items-table td:nth-child(1){width:78px}
.journal-invoice-items-table th:nth-child(2),.journal-invoice-items-table td:nth-child(2){width:42px}
.journal-invoice-items-table th:nth-child(3),.journal-invoice-items-table td:nth-child(3){width:64px}
.journal-invoice-items-table th:nth-child(4),.journal-invoice-items-table td:nth-child(4){width:auto;min-width:360px}
.journal-invoice-items-table th:nth-child(5),.journal-invoice-items-table td:nth-child(5){width:76px;white-space:nowrap;overflow:visible}
.journal-invoice-items-table th:nth-child(6),.journal-invoice-items-table td:nth-child(6){width:86px;white-space:nowrap;overflow:visible}
.journal-invoice-items-table th:nth-child(7),.journal-invoice-items-table td:nth-child(7){width:112px;white-space:nowrap;overflow:visible}
.journal-invoice-items-table th:nth-child(8),.journal-invoice-items-table td:nth-child(8){width:18%;min-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.journal-invoice-items-table th:nth-child(9),.journal-invoice-items-table td:nth-child(9){position:sticky;right:0;z-index:2;width:142px;white-space:nowrap;overflow:visible;background:#fff;box-shadow:-1px 0 0 var(--border)}
.journal-invoice-items-table thead th:nth-child(9){z-index:3;background:var(--bg)}
.journal-invoice-items-table td:nth-child(8){overflow:hidden;text-overflow:ellipsis}
.journal-invoice-items-table td:nth-child(9) .badge{vertical-align:middle}
.journal-invoice-items-no-operation th:nth-child(1),.journal-invoice-items-no-operation td:nth-child(1){width:42px}
.journal-invoice-items-no-operation th:nth-child(2),.journal-invoice-items-no-operation td:nth-child(2){width:64px}
.journal-invoice-items-no-operation th:nth-child(3),.journal-invoice-items-no-operation td:nth-child(3){width:auto;min-width:420px}
.journal-invoice-items-no-operation th:nth-child(4),.journal-invoice-items-no-operation td:nth-child(4){width:76px;white-space:nowrap;overflow:visible}
.journal-invoice-items-no-operation th:nth-child(5),.journal-invoice-items-no-operation td:nth-child(5){width:86px;white-space:nowrap;overflow:visible}
.journal-invoice-items-no-operation th:nth-child(6),.journal-invoice-items-no-operation td:nth-child(6){width:112px;white-space:nowrap;overflow:visible}
.journal-invoice-items-no-operation th:nth-child(7),.journal-invoice-items-no-operation td:nth-child(7){width:16%;min-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.journal-invoice-items-no-operation th:nth-child(8),.journal-invoice-items-no-operation td:nth-child(8){position:sticky;right:0;z-index:2;width:142px;white-space:nowrap;overflow:visible;background:#fff;box-shadow:-1px 0 0 var(--border)}
.journal-invoice-items-no-operation thead th:nth-child(8){z-index:3;background:var(--bg)}
.journal-invoice-items-no-operation td:nth-child(8) .badge{vertical-align:middle}
.journal-invoice-group-table th,.journal-invoice-group-table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.journal-invoice-group-table th:nth-child(1),.journal-invoice-group-table td:nth-child(1){width:84px}
.journal-invoice-group-table th:nth-child(2),.journal-invoice-group-table td:nth-child(2){width:auto;min-width:300px}
.journal-invoice-group-table th:nth-child(3),.journal-invoice-group-table td:nth-child(3){width:80px;white-space:nowrap;overflow:visible}
.journal-invoice-group-table th:nth-child(4),.journal-invoice-group-table td:nth-child(4){width:116px;white-space:nowrap;overflow:visible}
.journal-invoice-group-table th:nth-child(5),.journal-invoice-group-table td:nth-child(5){width:26%;min-width:240px}
.journal-invoice-group-table th:nth-child(6),.journal-invoice-group-table td:nth-child(6){width:142px;white-space:nowrap;overflow:visible}
.journal-invoice-group-table th:nth-child(7),.journal-invoice-group-table td:nth-child(7){width:44px}
.journal-supply-date-summary{margin:4px 0 8px}
.journal-supply-date-summary b{color:#31506f}
.journal-invoice-item-row{cursor:pointer}
.journal-invoice-item-row:hover td{background:#f8fafc}
.journal-item-rest{font-size:10px;color:var(--amber);line-height:1.05;margin-top:2px;font-weight:700}
.journal-object-short{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.journal-invoice-items-table tbody tr:not(.journal-section-row){height:30px}
.journal-invoice-items-table tbody tr:not(.journal-section-row)>td{height:30px;max-height:30px;line-height:1.15;vertical-align:middle;white-space:nowrap;text-overflow:ellipsis}
.journal-invoice-items-table tbody tr:not(.journal-section-row)>td>*:not(.journal-item-rest){max-height:18px;overflow:hidden;text-overflow:ellipsis}
.journal-invoice-items-table td:nth-child(4){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;overflow-wrap:normal;word-break:normal}
.journal-invoice-items-table.journal-invoice-items-payroll{min-width:0!important;width:100%!important;max-width:none!important;table-layout:fixed!important}
.journal-invoice-items-payroll th,.journal-invoice-items-payroll td{padding-top:4px;padding-bottom:4px}
.journal-invoice-items-payroll th:nth-child(1),.journal-invoice-items-payroll td:nth-child(1){width:44px}
.journal-invoice-items-payroll th:nth-child(2),.journal-invoice-items-payroll td:nth-child(2){width:auto;min-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.journal-invoice-items-payroll th:nth-child(3),.journal-invoice-items-payroll td:nth-child(3){width:128px;white-space:nowrap;overflow:visible}
.journal-invoice-items-payroll th:nth-child(4),.journal-invoice-items-payroll td:nth-child(4){position:static;width:150px;white-space:nowrap;overflow:visible;background:inherit;box-shadow:none}
.journal-invoice-items-payroll th:nth-child(1),.journal-invoice-items-payroll td:nth-child(1),
.journal-invoice-items-payroll th:nth-child(2),.journal-invoice-items-payroll td:nth-child(2),
.journal-invoice-items-payroll th:nth-child(3),.journal-invoice-items-payroll td:nth-child(3),
.journal-invoice-items-payroll th:nth-child(4),.journal-invoice-items-payroll td:nth-child(4){display:table-cell!important}
.journal-invoice-items-payroll tbody tr:not(.journal-section-row),.journal-invoice-items-payroll tbody tr:not(.journal-section-row)>td{height:26px;max-height:26px}
.journal-allocation-list{display:flex;flex-direction:column;gap:6px}
.journal-allocation-pill{display:grid;grid-template-columns:minmax(220px,1.7fr) minmax(70px,.45fr) minmax(110px,.55fr) minmax(90px,.65fr);gap:8px;align-items:center;padding:6px 8px;border:1px solid #e4edf7;border-radius:8px;background:#fff;font-size:12px}
.journal-allocation-pill b{font-size:12px;color:var(--text);font-weight:800}
.journal-allocation-pill span{font-variant-numeric:tabular-nums;white-space:nowrap}
.journal-allocation-pill em{font-style:normal;color:var(--muted);font-size:12px}
.journal-allocation-note{display:block;margin-top:2px;color:#64748b;font-weight:600}
.op-invoice-review{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.op-invoice-review-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}
.op-invoice-review-title{font-weight:800;font-size:15px}
.op-invoice-review-hint{font-size:12px;color:var(--muted);line-height:1.45;margin-top:2px}
.op-invoice-review-list{display:flex;flex-direction:column;gap:10px}
.op-invoice-review-item{border:1px solid #dbe4f0;border-radius:8px;background:#fff;overflow:hidden}
.op-invoice-review-item-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;padding:10px 12px;background:#f8fafc;border-bottom:1px solid #edf2f7}
.op-invoice-review-name{font-weight:800;line-height:1.3}
.op-invoice-review-name span{display:inline-block;margin-right:8px;color:#31506f}
.op-invoice-review-meta{font-size:12px;color:#334155;font-weight:800;white-space:nowrap}
.op-invoice-review-table{width:100%;border-collapse:collapse;font-size:13px}
.op-invoice-review-table th,.op-invoice-review-table td{padding:7px 10px;border-bottom:1px solid #edf2f7;text-align:left}
.op-invoice-review-table th{font-size:11px;color:var(--muted);background:#fbfdff}
.op-invoice-review-table tr:last-child td{border-bottom:0}
.op-invoice-review-table .num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.op-invoice-review-note{display:block;margin-top:2px;color:#64748b;font-size:12px;font-weight:600}
@media(max-width:800px){
  .contracts-toolbar{grid-template-columns:auto auto minmax(220px,1fr) auto}
  .contracts-toolbar .table-filter-result{display:none}
  .contracts-table{min-width:1080px}
  .contracts-col-contract{width:220px}
  .contracts-col-object{width:auto}
  .contracts-col-money{width:232px}
  .contracts-col-cost{width:232px}
  .contracts-col-deadline{width:190px}
  .contracts-col-status{width:132px}
  .contract-inline-indicator{gap:6px}
  .contract-inline-indicator .ci-value{font-size:11px}
  .contract-stage-deadline{gap:6px;min-height:42px}
  .contract-stage-deadline .deadline-date{font-size:11px}
  .journal-table{min-width:980px}
  .journal-col-id{width:86px}
  .journal-col-counterparty{width:160px}
  .journal-col-article{width:120px}
  .journal-col-qty{width:74px}
  .journal-col-amount{width:116px}
  .journal-col-objects{width:162px}
  .journal-table th,.journal-table td{padding-left:8px;padding-right:8px}
  .journal-detail-row .journal-invoice-items-table,.journal-detail-row .journal-invoice-group-table{min-width:100%!important;width:100%!important;max-width:none!important}
  .journal-invoice-items-table th:nth-child(1),.journal-invoice-items-table td:nth-child(1){width:68px}
  .journal-invoice-items-table th:nth-child(2),.journal-invoice-items-table td:nth-child(2){width:34px}
  .journal-invoice-items-table th:nth-child(3),.journal-invoice-items-table td:nth-child(3){width:54px}
  .journal-invoice-items-table th:nth-child(4),.journal-invoice-items-table td:nth-child(4){min-width:260px}
  .journal-invoice-items-table th:nth-child(5),.journal-invoice-items-table td:nth-child(5){width:70px}
  .journal-invoice-items-table th:nth-child(6),.journal-invoice-items-table td:nth-child(6){width:76px}
  .journal-invoice-items-table th:nth-child(7),.journal-invoice-items-table td:nth-child(7){width:92px}
  .journal-invoice-items-table th:nth-child(8),.journal-invoice-items-table td:nth-child(8){width:16%;min-width:130px}
  .journal-invoice-items-table th:nth-child(9),.journal-invoice-items-table td:nth-child(9){width:120px}
  .journal-invoice-items-no-operation th:nth-child(1),.journal-invoice-items-no-operation td:nth-child(1){width:36px}
  .journal-invoice-items-no-operation th:nth-child(2),.journal-invoice-items-no-operation td:nth-child(2){width:58px}
  .journal-invoice-items-no-operation th:nth-child(3),.journal-invoice-items-no-operation td:nth-child(3){min-width:280px}
  .journal-invoice-items-no-operation th:nth-child(4),.journal-invoice-items-no-operation td:nth-child(4){width:70px}
  .journal-invoice-items-no-operation th:nth-child(5),.journal-invoice-items-no-operation td:nth-child(5){width:76px}
  .journal-invoice-items-no-operation th:nth-child(6),.journal-invoice-items-no-operation td:nth-child(6){width:92px}
  .journal-invoice-items-no-operation th:nth-child(7),.journal-invoice-items-no-operation td:nth-child(7){width:16%;min-width:130px}
  .journal-invoice-items-no-operation th:nth-child(8),.journal-invoice-items-no-operation td:nth-child(8){width:120px}
  .journal-invoice-group-table th:nth-child(2),.journal-invoice-group-table td:nth-child(2){min-width:190px}
  .journal-invoice-group-table th:nth-child(5),.journal-invoice-group-table td:nth-child(5){width:22%;min-width:160px}
  .journal-invoice-items-table.journal-invoice-items-payroll{min-width:0!important;width:100%!important}
  .journal-invoice-items-payroll th:nth-child(1),.journal-invoice-items-payroll td:nth-child(1){width:40px}
  .journal-invoice-items-payroll th:nth-child(2),.journal-invoice-items-payroll td:nth-child(2){width:auto;min-width:160px}
  .journal-invoice-items-payroll th:nth-child(3),.journal-invoice-items-payroll td:nth-child(3){width:116px}
  .journal-invoice-items-payroll th:nth-child(4),.journal-invoice-items-payroll td:nth-child(4){width:138px}
}
.primary-source{display:inline-flex;align-items:center;justify-content:center;min-width:58px;padding:3px 8px;border-radius:999px;background:#eef4fb;color:#31506f;font-size:11px;font-weight:800}
.primary-row-title{font-weight:700;color:var(--text);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.primary-row-meta{font-size:11px;color:var(--muted);line-height:1.25;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.primary-date-main{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.primary-actions{display:flex;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.primary-actions .btn{padding:5px 9px;font-size:12px;min-height:30px}
.primary-table{table-layout:fixed}
.primary-table th,.primary-table td{vertical-align:top}
.primary-table td,.primary-table th{overflow:hidden}
.primary-table tbody tr.primary-main-row{cursor:pointer}
.primary-table tbody tr.primary-main-row.is-open{background:#eef6ff;box-shadow:inset 4px 0 var(--green)}
.primary-table tbody tr.primary-detail-row>td{background:#f8fafc;padding:0 18px 16px;box-shadow:inset 4px 0 var(--green)}
.primary-detail-panel{border:1px solid var(--border);border-top:0;border-radius:0 0 10px 10px;background:#fff;overflow:hidden}
.primary-detail-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}
.primary-detail-head b{font-size:13px}
.primary-detail-sub{font-size:12px;color:var(--muted)}
.primary-source-table{width:100%;table-layout:fixed;font-size:12px}
.primary-source-table th,.primary-source-table td{padding:10px 12px;vertical-align:top}
.primary-source-table th{font-size:10px}

/* Unified expanded registry rows: journal, objects, contracts, primary, finance. */
.journal-table.journal-has-open tbody tr.journal-row,
.objects-table.objects-has-open tbody tr.object-row,
.contracts-table.contracts-has-open tbody tr.contracts-row,
.primary-table.primary-has-open tbody tr.primary-main-row,
.finance-ledger-table.finance-has-open tbody tr.finance-ledger-row{opacity:.45}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open,
.objects-table.objects-has-open tbody tr.object-row.object-row-open,
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open,
.primary-table.primary-has-open tbody tr.primary-main-row.is-open,
.finance-ledger-table.finance-has-open tbody tr.finance-ledger-row.finance-row-open{opacity:1;box-shadow:none}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open>td,
.objects-table.objects-has-open tbody tr.object-row.object-row-open>td,
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open>td,
.primary-table.primary-has-open tbody tr.primary-main-row.is-open>td,
.finance-ledger-table.finance-has-open tbody tr.finance-ledger-row.finance-row-open>td{background:#eef6ff}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open:hover>td,
.objects-table.objects-has-open tbody tr.object-row.object-row-open:hover>td,
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open:hover>td,
.primary-table.primary-has-open tbody tr.primary-main-row.is-open:hover>td,
.finance-ledger-table.finance-has-open tbody tr.finance-ledger-row.finance-row-open:hover>td{background:#eaf4ff}
.journal-table.journal-has-open tbody tr.journal-row.journal-row-open>td:first-child,
.objects-table.objects-has-open tbody tr.object-row.object-row-open>td:first-child,
.contracts-table.contracts-has-open tbody tr.contracts-row.contract-row-open>td:first-child,
.primary-table.primary-has-open tbody tr.primary-main-row.is-open>td:first-child,
.finance-ledger-table.finance-has-open tbody tr.finance-ledger-row.finance-row-open>td:first-child,
.journal-table tbody tr.journal-detail-row.is-open>td,
.objects-table tbody tr.objects-detail-row.is-open>td,
.contracts-table tbody tr.contracts-detail-row.is-open>td,
.primary-table tbody tr.primary-detail-row.is-open>td,
.finance-ledger-table tbody tr.finance-ledger-detail-row.is-open>td{box-shadow:inset 4px 0 var(--green)}
.journal-table tbody tr.journal-detail-row>td,
.objects-table tbody tr.objects-detail-row>td,
.contracts-table tbody tr.contracts-detail-row>td,
.primary-table tbody tr.primary-detail-row>td,
.finance-ledger-table tbody tr.finance-ledger-detail-row>td{background:#f8fafc;border-top:0}
.primary-source-text{white-space:normal;overflow-wrap:anywhere;line-height:1.35}
.primary-expand-mark{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:6px;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-size:11px;background:#fff}
.primary-review-badge{border:0;cursor:pointer;font:inherit}
.primary-review-badge:hover{box-shadow:0 0 0 3px rgba(245,158,11,.18)}
.primary-review-hero{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(260px,.7fr);gap:14px;margin-bottom:16px}
.primary-review-card{border:1px solid var(--border);border-radius:10px;background:#fff;padding:14px}
.primary-review-card.accent{border-color:#FCD34D;background:#FFFBEB}
.primary-review-card h4{margin:0 0 8px;font-size:14px}
.primary-review-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}
.primary-review-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}
.primary-review-fact{background:#F8FAFC;border:1px solid var(--border);border-radius:8px;padding:8px 10px;min-width:0}
.primary-review-fact span{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;font-weight:800;margin-bottom:3px}
.primary-review-fact b{display:block;font-size:13px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.primary-review-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.primary-review-message{white-space:pre-wrap;line-height:1.45;background:#F8FAFC;border:1px solid var(--border);border-radius:10px;padding:12px;max-height:180px;overflow:auto}
.primary-review-warnings{display:grid;gap:6px;margin-top:10px}
.primary-review-warning{border:1px solid #FCD34D;background:#FFFBEB;color:#7C2D12;border-radius:8px;padding:8px 10px;font-size:12px;line-height:1.35}
.primary-review-lines{width:100%;table-layout:fixed;font-size:12px}
.primary-review-lines th,.primary-review-lines td{padding:8px 10px;vertical-align:top}
.primary-review-lines th{font-size:10px}
.primary-review-lines .num{text-align:right;white-space:nowrap}
.primary-review-form-title{font-weight:800;margin:8px 0 10px}
.toast-stack{position:fixed;right:20px;bottom:20px;z-index:220;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast-stack.center{top:0;left:0;right:0;bottom:0;align-items:center;justify-content:center;background:rgba(15,23,42,.08)}
.toast{min-width:260px;max-width:420px;padding:12px 14px;border-radius:10px;background:#fff;border:1px solid var(--border);box-shadow:0 16px 42px rgba(15,23,42,.16);font-size:14px;font-weight:700;line-height:1.35;opacity:0;transform:translateY(8px);transition:.18s ease}
.toast-stack.center .toast{font-size:16px;padding:16px 20px;text-align:center}
.toast.show{opacity:1;transform:translateY(0)}
.toast.success{border-color:#BBF7D0;background:#F0FDF4;color:#166534}
.primary-toolbar{display:grid;grid-template-columns:minmax(170px,1fr) minmax(260px,390px) minmax(90px,160px) auto;align-items:center}
.primary-toolbar .journal-status-label{justify-self:end}
.primary-col-source{width:110px}
.primary-col-date{width:170px}
.primary-col-title{width:auto}
.primary-col-status{width:190px}
.primary-col-link{width:170px}
.primary-col-actions{width:170px}
.primary-table th:nth-last-child(-n+3),.primary-table td:nth-last-child(-n+3){white-space:nowrap;overflow:visible}
.primary-table td:nth-last-child(-n+2) .badge,.primary-table td:last-child .btn{display:inline-flex;max-width:none}
.journal-doc-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.journal-doc-link{border:1px solid #dbe4f0;background:#fff;border-radius:8px;padding:6px 10px;font-size:12px;font-weight:700;color:#31506f;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.journal-doc-link:hover{border-color:var(--green);color:var(--green-d);background:var(--selected-bg)}
.journal-doc-list{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.journal-doc-inline{display:inline-flex;align-items:center;min-height:32px;max-width:100%;border:1px solid #dbe4f0;background:#fff;border-radius:6px;padding:6px 10px;color:var(--text);text-decoration:none;font-size:13px;font-weight:500;line-height:1.25;cursor:pointer;box-shadow:0 1px 0 rgba(15,23,42,.03)}
.journal-doc-inline:hover{border-color:var(--green);color:var(--green-d);background:var(--selected-bg)}
.document-viewer-modal{position:fixed;inset:0;background:rgba(15,23,42,.72);z-index:220;display:none;align-items:stretch;justify-content:center;padding:22px}
.document-viewer-modal.open{display:flex}
.document-viewer-card{background:#fff;border-radius:12px;box-shadow:0 24px 70px rgba(15,23,42,.36);width:min(1120px,100%);height:100%;display:flex;flex-direction:column;overflow:hidden}
.document-viewer-head{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border)}
.document-viewer-head b{font-size:14px;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.document-viewer-head .btn{margin-left:auto}
.document-viewer-frame{border:0;width:100%;height:100%;background:#f8fafc}
.document-viewer-body{flex:1;overflow:auto;background:#111827;padding:18px}
.document-viewer-loading{color:#cbd5e1;font-size:14px;padding:24px;text-align:center}
.document-page{display:block;margin:0 auto 18px;background:#fff;box-shadow:0 10px 28px rgba(0,0,0,.32);max-width:100%;height:auto}
.document-image{display:block;margin:0 auto;background:#fff;box-shadow:0 10px 28px rgba(0,0,0,.32);max-width:100%;height:auto}
.alloc-assist-panel{display:grid;grid-template-columns:auto minmax(160px,1fr) minmax(120px,.55fr) auto;gap:8px;align-items:center;background:#f8fafc;border:1px solid #dbe4f0;border-radius:8px;padding:8px 10px;margin-bottom:8px}
.alloc-assist-title{font-size:12px;font-weight:800;color:#31506f;white-space:nowrap}
.alloc-tabs{display:flex;gap:4px;align-items:flex-end;margin:2px 0 8px;border-bottom:1px solid #dbe4f0}
.alloc-tab{appearance:none;border:1px solid transparent;border-bottom:0;background:transparent;color:var(--muted);font:inherit;font-size:12px;font-weight:800;padding:7px 10px;border-radius:8px 8px 0 0;cursor:pointer}
.alloc-tab:hover{color:#31506f;background:#f8fafc}
.alloc-tab.active{color:#244967;background:#fff;border-color:#dbe4f0;box-shadow:0 1px 0 #fff}
.alloc-pane{display:none}
.alloc-pane.active{display:block}
.alloc-preset-field{display:block;min-width:0}
.alloc-preset-field span{display:none}
.alloc-preset-field select{box-sizing:border-box;min-width:0;width:100%;min-height:34px;border-radius:8px;border:1px solid #dbe4f0;padding:5px 10px;font-size:13px;background:#fff}
.alloc-list-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:8px 0 6px;font-size:12px;color:var(--muted);font-weight:700}
.alloc-row{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(0,1.25fr) minmax(120px,.8fr) 32px;gap:8px;align-items:center;background:#fff;border:1px solid #dbe4f0;border-radius:8px;padding:8px}
.alloc-row > select,.alloc-row > input{box-sizing:border-box;min-width:0;width:100%;min-height:36px;border-radius:8px;border:1px solid #dbe4f0;padding:6px 10px;font-size:13px;background:#fff}
.alloc-object-select{font-weight:700;color:var(--text)}
.a-qty,.op-line-alloc-qty{font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.alloc-auto-qty{box-sizing:border-box;min-width:0;width:100%;min-height:34px;border-radius:8px;border:1px solid #dbe4f0;padding:5px 10px;font-size:13px;font-weight:700;color:#244967;background:#fff;font-variant-numeric:tabular-nums}
.alloc-row > button{min-height:36px;align-self:center}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:100;align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:16px;max-width:560px;width:100%;max-height:90vh;overflow-y:auto;scrollbar-gutter:stable;box-shadow:0 20px 50px rgba(0,0,0,.2)}
.modal-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.modal-head h3{font-size:17px;font-weight:700}
.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);padding:0;width:28px;height:28px}
.modal-body{padding:22px}
.modal-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--bg)}

/* MISC */
.alert{padding:14px 16px;border-radius:10px;margin-bottom:16px;display:flex;gap:12px;align-items:start}
.alert-red{background:var(--red-l);color:var(--red);border:1px solid #FCA5A5}
.alert-amber{background:var(--amber-l);color:var(--amber);border:1px solid #FCD34D}
.alert .ico{font-size:18px}
.alert-body{flex:1;font-size:13px}
.alert-title{font-weight:700;margin-bottom:2px}

.sub-tabs{display:flex;gap:10px;border-bottom:1px solid var(--border);margin-bottom:20px;align-items:flex-start;padding-bottom:8px}
.sub-tab{padding:8px 12px;cursor:pointer;font-weight:600;color:#5C7695;font-size:17px;line-height:1.2;border:1px solid transparent;border-radius:10px;display:flex;flex-direction:column;gap:3px;white-space:nowrap}
.sub-tab:hover{background:var(--selected-bg);border-color:#D9E3EF;color:var(--green-d)}
.sub-tab.active{background:var(--selected-bg);color:var(--green-d);border-color:var(--green);box-shadow:var(--selected-ring)}
.sub-tab-count{font-size:15px;font-weight:600}

.empty{padding:40px;text-align:center;color:var(--muted)}
.empty .ico{font-size:40px;margin-bottom:10px;opacity:.4}

/* View switcher */
.view-switch{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#fff}
.view-switch-btn{padding:7px 12px;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;border-right:1px solid var(--border);font-family:inherit}
.view-switch-btn:last-child{border-right:none}
.view-switch-btn:hover{background:var(--green-bg);color:var(--green-d)}
.view-switch-btn.active{background:var(--selected-bg);color:var(--green-d);box-shadow:inset 0 0 0 2px var(--green)}

/* Kanban */
.kb-scroll{overflow-x:auto;padding-bottom:6px}
.kb-board{display:grid;grid-template-columns:repeat(var(--kb-columns,5),minmax(0,1fr));gap:12px;align-items:stretch;min-width:1000px}
.kb-column{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;min-height:100px;min-width:0}
.kb-col-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}
.kb-count{font-weight:700;color:var(--muted);font-size:12px}
.kb-col-sub{font-size:11px;color:var(--muted);margin-bottom:10px}
.kb-col-body{display:flex;flex-direction:column;gap:8px}
.kb-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:10px 12px;cursor:pointer;transition:all .12s;box-shadow:var(--shadow)}
.kb-card:hover{border-color:var(--green);box-shadow:var(--shadow-m)}
.kb-name{font-weight:700;font-size:13px;overflow-wrap:anywhere;word-break:break-word}
.kb-type{font-size:11px;color:var(--muted);margin-top:2px;overflow-wrap:anywhere;word-break:break-word}
.kb-money{display:flex;justify-content:space-between;font-size:11px;font-weight:600;margin-top:6px;font-variant-numeric:tabular-nums}
.kb-empty{color:var(--muted);font-size:12px;text-align:center;padding:14px 0;border:1px dashed var(--border);border-radius:8px}

/* Inline edit */
.cell-edit{cursor:text;position:relative}
.cell-edit:hover{background:var(--green-bg) !important;outline:1px dashed var(--green-l);outline-offset:-2px}
.inline-edit{width:100%;padding:4px 6px;border:1px solid var(--green);border-radius:4px;font-size:13px;font-family:inherit;background:#fff;box-sizing:border-box}
.inline-edit:focus{outline:none;box-shadow:0 0 0 3px var(--green-l)}

/* DnD feedback */
.dnd-dragging{opacity:.4 !important}
.kb-drop-hover{outline:2px dashed var(--green);outline-offset:-6px;background:var(--green-bg) !important}
.kb-col-drop-hover{outline:2px dashed var(--blue);outline-offset:-3px}
.obj-card.dnd-drop-before{border-left:3px solid var(--green)}
.obj-card.dnd-drop-after{border-right:3px solid var(--green)}
@media (max-width:800px){.kb-board{min-width:840px}}

/* Permission matrix */
.perm-matrix-header{display:flex;background:var(--bg);border-bottom:1px solid var(--border);font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;position:sticky;top:0;z-index:2}
.perm-matrix-row{display:flex;border-bottom:1px solid var(--border);font-size:13px;align-items:center;min-height:38px}
.perm-matrix-row:hover{background:var(--green-bg)}
.perm-matrix-row.perm-master{background:#F8FAFC}
.perm-matrix-row.perm-master:hover{background:var(--green-bg)}
.perm-matrix-cell{padding:8px 10px;display:flex;align-items:center}
.perm-matrix-cell.modules-col{flex:1;min-width:240px}
.perm-matrix-cell.action-col{width:84px;justify-content:center;border-left:1px solid var(--border);flex-shrink:0}
.perm-ico{display:inline-flex;align-items:center;justify-content:center;width:20px;margin-right:8px;color:var(--muted)}
.pm-check{display:flex;align-items:center;justify-content:center;width:22px;height:22px;cursor:pointer}
.pm-check input{width:16px;height:16px;cursor:pointer;accent-color:var(--green)}

.nav-action{background:#F0FDF4;color:var(--green-d);box-shadow:inset 0 0 0 1px #BBF7D0}
.nav-action:hover{background:#DCFCE7;color:var(--green-d)}
.quick-expense-modal{max-width:720px;border-radius:14px}
.quick-expense-modal .modal-head{align-items:flex-start;background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)}
.quick-expense-modal .modal-head h3{font-size:22px;margin:0 0 4px}
.quick-expense-lead{color:var(--muted);line-height:1.4;margin:0;max-width:560px;font-size:13px}
.quick-expense-body{background:#fff}
.quick-expense-intro{padding:10px 12px;border:1px solid #D9E3EF;border-radius:10px;background:#F8FAFC;color:#425B78;font-size:13px;line-height:1.4;margin-bottom:14px}
.quick-expense-form{display:grid;gap:14px}
.quick-expense-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.quick-expense-hint{font-size:11px;color:var(--green-d);min-height:14px}
.quick-expense-hint[hidden]{display:block;visibility:hidden}
.quick-expense-smart-hints{display:grid;gap:4px;padding:10px 12px;border:1px solid #BFDBFE;border-radius:10px;background:#EFF6FF;color:#31506F;font-size:12px;line-height:1.35}
.quick-expense-extra{border:1px solid var(--border);border-radius:10px;padding:12px;background:#F8FAFC}
.quick-expense-extra summary{cursor:pointer;font-weight:700;color:var(--text);margin-bottom:10px}
.quick-expense-extra:not([open]) summary{margin-bottom:0}
@media(max-width:980px){.kpi-grid,.section-kpi-grid,.finance-summary,.journal-kpi-grid,.objects-kpi-strip,.objects-section-strip{grid-template-columns:repeat(2,minmax(0,1fr)) !important}.grid-2{grid-template-columns:1fr}.sidebar{width:64px}.logo-text,.nav-item span:not(.ico):not(.nav-badge),.user-info{display:none}.settings-pane-head{padding:14px 16px;gap:12px;flex-direction:column;align-items:flex-start}.settings-pane-groups{gap:10px}.settings-groups-divider{margin-left:16px}.sub-tabs{gap:18px;overflow:auto;padding-bottom:2px}.sub-tab{font-size:16px}.sub-tab-count{font-size:14px}thead th,tbody td{padding-left:16px;padding-right:16px}thead th{padding-top:10px;padding-bottom:10px}tbody td{padding-top:14px;padding-bottom:14px}.form-row-3,.op-meta-row,.op-money-row,.op-amount-grid,.quick-expense-grid{grid-template-columns:1fr}.op-qty-inner{grid-template-columns:1fr}.max-chat-explain{grid-template-columns:1fr}.max-member-card{grid-template-columns:1fr 1fr}.max-member-summary{grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) 26px}.max-member-right{grid-column:1 / -1;grid-row:2;justify-content:flex-start;text-align:left}.max-member-detail-grid{grid-template-columns:1fr}.max-member-permissions,.max-member-action{grid-column:1 / -1}.max-member-action{text-align:left}}
@media(max-width:720px){.op-kind-row{grid-template-columns:1fr;min-width:0;max-width:none;width:100%}.op-kind-btn{min-width:0}.op-modal-head{grid-template-columns:1fr auto;gap:10px}.op-header-field{grid-column:1 / -1}.op-header-field input,.op-header-field select{width:100%}.op-modal-actions{grid-column:1 / -1;grid-row:2;justify-content:flex-start;flex-wrap:wrap}.op-modal .modal-close{grid-column:2;grid-row:1;justify-self:end}}
@media(min-width:641px) and (max-width:1440px){
  .sidebar{width:64px;z-index:50;overflow:hidden}
  .sidebar:hover,.sidebar:focus-within{width:240px;box-shadow:12px 0 28px rgba(15,23,42,.10)}
  .logo{justify-content:center;padding:18px 10px}
  .logo-text,.user-info,.nav-item span:not(.ico):not(.nav-badge):not(.nav-drag-handle){display:none}
  .sidebar:hover .logo,.sidebar:focus-within .logo{justify-content:flex-start;padding:20px}
  .sidebar:hover .logo-text,.sidebar:focus-within .logo-text{display:block}
  .sidebar:hover .user-info,.sidebar:focus-within .user-info{display:block}
  .nav{padding:12px 8px}
  .nav-item{grid-template-columns:1fr;justify-items:center;column-gap:0;padding:10px 0;min-height:42px}
  .nav-item:hover,.nav-item.nav-dragging{padding:10px 0}
  .nav-item .ico{width:100%;text-align:center}
  .sidebar:hover .nav-item,.sidebar:focus-within .nav-item{grid-template-columns:18px minmax(0,1fr) max-content;justify-items:stretch;column-gap:10px;padding:10px 12px}
  .sidebar:hover .nav-item:hover,.sidebar:focus-within .nav-item:hover,.sidebar:hover .nav-item.nav-dragging,.sidebar:focus-within .nav-item.nav-dragging{padding-left:14px;padding-right:34px}
  .sidebar:hover .nav-item .ico,.sidebar:focus-within .nav-item .ico{width:18px;text-align:center}
  .sidebar:hover .nav-item span:not(.ico):not(.nav-badge):not(.nav-drag-handle),.sidebar:focus-within .nav-item span:not(.ico):not(.nav-badge):not(.nav-drag-handle){display:block}
  .sidebar:not(:hover):not(:focus-within) .nav-badge,.sidebar:not(:hover):not(:focus-within) .nav-drag-handle{display:none}
  .user{justify-content:center;padding:12px 8px}
  .sidebar:hover .user,.sidebar:focus-within .user{justify-content:flex-start;padding:12px}
}
@media(max-width:640px){
  html{font-size:15px}
  body{display:block;min-height:100dvh;padding:0 0 calc(76px + env(safe-area-inset-bottom));overflow-x:hidden}
  .sidebar{position:fixed;left:0;right:0;bottom:0;top:auto;z-index:90;width:100%;height:auto;border-right:0;border-top:1px solid var(--border);box-shadow:0 -8px 24px rgba(15,23,42,.08);background:rgba(255,255,255,.96);backdrop-filter:saturate(140%) blur(10px)}
  .logo,.user{display:none}
  .nav{display:flex;gap:6px;align-items:stretch;overflow-x:auto;overflow-y:hidden;padding:8px 8px calc(8px + env(safe-area-inset-bottom));scrollbar-width:none}
  .nav::-webkit-scrollbar{display:none}
  .nav-item{display:flex;flex:0 0 76px;min-height:54px;margin:0;padding:7px 6px;border-radius:12px;flex-direction:column;justify-content:center;gap:4px;font-size:10px;text-align:center;color:#5C7695}
  .nav-item:hover,.nav-item.nav-dragging{padding:7px 18px 7px 6px}
  .nav-item span:not(.ico):not(.nav-badge):not(.nav-drag-handle){display:block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .nav-item .ico{width:auto;font-size:17px;line-height:1}
  .nav-drag-handle{top:4px;right:4px;transform:none}
  .nav-badge{position:absolute;top:3px;right:7px;margin:0;font-size:10px;padding:1px 5px}
  .nav-item{position:relative}
  .nav-item[draggable="true"]{user-select:auto}
  .main{width:100%;min-width:0}
  .topbar{height:auto;min-height:58px;padding:10px 12px;gap:8px;align-items:center;flex-wrap:wrap}
  .topbar .global-search-box{order:1;flex:1 1 100%;width:100%;max-width:none}
  .topbar .search{width:100%;height:38px;font-size:14px}
  .global-search-results{width:calc(100vw - 24px);max-height:72vh}
  .topbar .spacer{display:none}
  .topbar .btn{flex:1 1 0;justify-content:center;min-height:38px;padding:8px 10px;font-size:12px;white-space:nowrap}
  .content{padding:16px 12px;max-width:none}
  .page-head{display:block;margin-bottom:14px}
  .page-head h2{font-size:22px;line-height:1.2;margin-bottom:4px}
  .page-head p{font-size:13px}
  .page-title-tools{flex-wrap:wrap}
  .page-title-actions{width:100%;margin-left:0;margin-top:8px;overflow-x:auto;padding:1px 1px 2px;scrollbar-width:none}
  .page-title-actions::-webkit-scrollbar{display:none}
  .page-title-actions .btn{flex:0 0 auto}
  .page-head > div:last-child,.finance-actions{display:flex;gap:8px;overflow-x:auto;padding:8px 1px 2px;margin:8px -1px 0;scrollbar-width:none}
  .page-head > div:last-child::-webkit-scrollbar,.finance-actions::-webkit-scrollbar{display:none}
  .page-head .btn,.finance-actions .btn{flex:0 0 auto;min-height:38px}
  .kpi-grid,.section-kpi-grid,.finance-summary,.journal-kpi-grid,.objects-kpi-strip,.objects-section-strip{display:flex;gap:10px;overflow-x:auto;margin:0 -12px 14px;padding:0 12px 4px;scroll-snap-type:x proximity;scrollbar-width:none}
  .kpi-grid::-webkit-scrollbar,.section-kpi-grid::-webkit-scrollbar,.finance-summary::-webkit-scrollbar,.journal-kpi-grid::-webkit-scrollbar,.objects-kpi-strip::-webkit-scrollbar,.objects-section-strip::-webkit-scrollbar{display:none}
  .kpi{--kpi-height:88px;flex:0 0 76%;padding:9px 14px;scroll-snap-align:start;border-radius:8px}
  .kpi-label{font-size:11px}
  .grid-2{display:block}
  .card{padding:14px;border-radius:10px;margin-bottom:12px}
  .obj-grid{grid-template-columns:1fr;gap:10px}
  .obj-card{padding:14px;border-radius:10px}
  .sub-tabs{margin:0 -12px 14px;padding:0 12px 8px;gap:8px;overflow-x:auto;border-bottom:0}
  .sub-tab{font-size:14px;border-color:var(--border);background:#fff;border-radius:999px;padding:8px 12px;display:inline-flex;flex-direction:row;align-items:center;gap:6px}
  .sub-tab-count{font-size:12px}
  .view-switch{max-width:100%;overflow-x:auto}
  .view-switch-btn{white-space:nowrap}
  .table-wrap{border-radius:10px;margin-left:0;margin-right:0;overflow-x:auto;box-shadow:none}
  .table-wrap table th:last-child,.table-wrap table td:last-child{position:sticky;right:0;z-index:2;background:#fff;box-shadow:-1px 0 0 var(--border)}
  .table-wrap table thead th:last-child{z-index:8;background:var(--bg)}
  .table-top{position:sticky;left:0;z-index:1;display:block;padding:12px;background:#fff}
  .table-top b{display:inline-flex;margin-bottom:8px;font-size:15px}
  .table-filter-toggle,.journal-filter-toggle{margin-left:8px}
  .table-filter-chip-row{display:flex;margin:8px -2px 0;gap:8px;overflow-x:auto;flex-wrap:nowrap;padding:2px 2px 4px;scrollbar-width:none}
  .table-filter-chip-row::-webkit-scrollbar{display:none}
  .filter-chip{flex:0 0 auto;white-space:nowrap}
  .table-filter-search{width:100%;border-radius:10px;margin-top:6px}
  .table-filter-panel{grid-template-columns:1fr;padding-top:8px}
  table{min-width:720px;font-size:13px}
  .journal-invoice-items-table{min-width:0;width:calc(100vw - 96px);max-width:100%}
  .journal-invoice-items-table th:nth-child(2),.journal-invoice-items-table td:nth-child(2),
  .journal-invoice-items-table th:nth-child(3),.journal-invoice-items-table td:nth-child(3),
  .journal-invoice-items-table th:nth-child(5),.journal-invoice-items-table td:nth-child(5),
  .journal-invoice-items-table th:nth-child(6),.journal-invoice-items-table td:nth-child(6),
  .journal-invoice-items-table th:nth-child(8),.journal-invoice-items-table td:nth-child(8){display:none}
  .journal-invoice-items-table th,.journal-invoice-items-table td{padding-left:6px;padding-right:6px}
  .journal-invoice-items-table th:nth-child(1),.journal-invoice-items-table td:nth-child(1){width:68px}
  .journal-invoice-items-table th:nth-child(4),.journal-invoice-items-table td:nth-child(4){width:auto;min-width:110px}
  .journal-invoice-items-table th:nth-child(7),.journal-invoice-items-table td:nth-child(7){width:84px}
  .journal-invoice-items-table th:nth-child(9),.journal-invoice-items-table td:nth-child(9){position:static;width:86px;background:inherit;box-shadow:none}
  .journal-invoice-items-table td:nth-child(9) .badge{max-width:82px;overflow:hidden;text-overflow:ellipsis}
  .journal-invoice-items-table thead th:nth-child(9){background:var(--bg)}
  .journal-invoice-items-no-operation th:nth-child(1),.journal-invoice-items-no-operation td:nth-child(1),
  .journal-invoice-items-no-operation th:nth-child(2),.journal-invoice-items-no-operation td:nth-child(2),
  .journal-invoice-items-no-operation th:nth-child(4),.journal-invoice-items-no-operation td:nth-child(4),
  .journal-invoice-items-no-operation th:nth-child(5),.journal-invoice-items-no-operation td:nth-child(5),
  .journal-invoice-items-no-operation th:nth-child(7),.journal-invoice-items-no-operation td:nth-child(7){display:none}
  .journal-invoice-items-no-operation th:nth-child(3),.journal-invoice-items-no-operation td:nth-child(3){width:auto;min-width:110px}
  .journal-invoice-items-no-operation th:nth-child(6),.journal-invoice-items-no-operation td:nth-child(6){width:84px}
  .journal-invoice-items-no-operation th:nth-child(8),.journal-invoice-items-no-operation td:nth-child(8){position:static;width:86px;background:inherit;box-shadow:none}
  .journal-invoice-items-no-operation td:nth-child(8) .badge{max-width:82px;overflow:hidden;text-overflow:ellipsis}
  .journal-invoice-items-no-operation thead th:nth-child(8){background:var(--bg)}
  .journal-invoice-items-table.journal-invoice-items-payroll{width:100%!important;min-width:0!important}
  .journal-invoice-items-payroll th:nth-child(2),.journal-invoice-items-payroll td:nth-child(2),
  .journal-invoice-items-payroll th:nth-child(3),.journal-invoice-items-payroll td:nth-child(3){display:table-cell}
  .journal-invoice-items-payroll th:nth-child(1),.journal-invoice-items-payroll td:nth-child(1){width:34px}
  .journal-invoice-items-payroll th:nth-child(2),.journal-invoice-items-payroll td:nth-child(2){width:auto;min-width:120px}
  .journal-invoice-items-payroll th:nth-child(3),.journal-invoice-items-payroll td:nth-child(3){width:108px}
  .journal-invoice-items-payroll th:nth-child(4),.journal-invoice-items-payroll td:nth-child(4){position:static;width:112px;background:inherit;box-shadow:none}
  .journal-invoice-items-payroll td:nth-child(4) .badge{max-width:108px;overflow:hidden;text-overflow:ellipsis}
  .journal-allocation-pill{grid-template-columns:1fr}
  .op-invoice-review-head,.op-invoice-review-item-head{grid-template-columns:1fr}
  .op-invoice-review-table th:nth-child(4),.op-invoice-review-table td:nth-child(4){display:none}
  thead th,tbody td{padding:11px 12px}
  tbody td{vertical-align:top}
  .settings-pane{border-radius:10px;margin-left:-12px;margin-right:-12px;border-left:0;border-right:0}
  .settings-pane-head{padding:12px}
  .settings-chip{min-height:36px;padding:0 12px}
  .max-member-card{grid-template-columns:1fr;padding:14px}
  .max-member-summary{grid-template-columns:1fr 24px;padding:12px 14px}
  .max-member-employee,.max-member-right{grid-column:1 / -1}
  .max-member-details{padding:0 14px 14px}
  .max-member-permissions,.max-member-action{grid-column:auto}
  .max-member-action .btn{width:100%;justify-content:center}
  .form-row,.form-row-3,.form-row-full,.op-meta-row,.op-money-row,.op-amount-grid{grid-template-columns:1fr}
    .op-item-line{grid-template-columns:1fr 1fr}
    .op-items-bulk-row{grid-template-columns:1fr}
    .op-items-bulk-prorata-btn{align-self:stretch;width:100%}
    .op-items-bulk-field>span{white-space:normal}
    .op-items-bulk-prorata-row{grid-template-columns:minmax(0,1fr) 90px 28px}
    .op-line-quick-split-row{grid-template-columns:minmax(0,1fr) 110px 28px}
    .op-line-alloc-row{grid-template-columns:1fr}
  .alloc-assist-panel{grid-template-columns:1fr}
  .op-line-alloc-toggle-row{justify-content:stretch}
  .op-line-alloc-toggle{width:100%}
  .op-item-line .op-line-remove{grid-column:1 / -1}
  .op-items-summary{grid-template-columns:1fr}
  .journal-detail-grid{grid-template-columns:1fr}
  .journal-table .journal-main-text,.journal-table .journal-sub-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:normal}
  .field input,.field select,.field textarea,.search-select-input{min-height:42px;font-size:16px}
  .modal-bg{align-items:stretch;justify-content:stretch;padding:0;z-index:120}
  .modal{width:100%;max-width:none;height:100dvh;max-height:100dvh;border-radius:0;display:flex;flex-direction:column;overflow:hidden}
  .modal-head{padding:14px 16px;min-height:58px;flex-shrink:0}
  .modal-head h3{font-size:18px;line-height:1.25}
  .modal-close{width:38px;height:38px;font-size:24px}
  .modal-body{padding:16px;overflow-y:auto;flex:1;min-height:0}
  .modal-foot{padding:12px 16px calc(12px + env(safe-area-inset-bottom));gap:8px;flex-shrink:0;justify-content:stretch}
  .modal-foot .btn{flex:1;justify-content:center;min-height:44px}
  .modal.op-modal{width:100%;max-width:none;height:100dvh;max-height:100dvh;border-radius:0}
  .op-modal .modal-head{padding:12px 14px}
  .op-modal .modal-body{padding:12px 14px 0}
  .op-modal .modal-foot{padding:10px 14px calc(10px + env(safe-area-inset-bottom))}
  .op-modal-title{white-space:normal;font-size:18px}
  .op-modal-actions{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}
  .op-kind-row{display:grid;grid-template-columns:1fr;width:100%;min-width:0}
  .op-kind-btn{min-width:0;min-height:56px;padding:8px 10px}
  .op-main-details > summary{align-items:flex-start}
  .op-main-summary{white-space:normal}
  .alloc-row{grid-template-columns:1fr;gap:8px;padding:10px 0;border-bottom:1px solid var(--border)}
  .alloc-row > button{width:100%;justify-content:center}
  .kb-scroll{margin-left:-12px;margin-right:-12px;padding-left:12px}
  .kb-board{min-width:760px}
}
/* Payroll */
.payroll-head{align-items:flex-start}
.payroll-tabs{margin:0 0 18px}
.payroll-tabs button.sub-tab{appearance:none;background:#fff;font:inherit}
.payroll-card{padding:0;overflow:hidden}
.payroll-controls{display:grid;grid-template-columns:110px 100px 170px minmax(260px,1fr) max-content;gap:12px;align-items:end;padding:18px;border-bottom:1px solid var(--line)}
.payroll-controls label,.payroll-form-grid label{display:flex;flex-direction:column;gap:6px;font-weight:700;color:var(--muted);font-size:13px}
.payroll-controls input,.payroll-controls select,.payroll-form-grid input,.payroll-form-grid select,.payroll-form-grid textarea,.payroll-table input,.payroll-table select{border:1px solid #D8E2EF;border-radius:10px;padding:10px 12px;background:#fff;color:var(--text);font:inherit;min-height:42px}
.payroll-preview-empty{padding:22px;color:var(--muted)}
.payroll-preview-box{padding:0}
.payroll-preview-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid var(--line);background:#F8FAFC}
.payroll-total{font-size:22px;font-weight:800;white-space:nowrap}
.payroll-table{width:100%;border-collapse:collapse;table-layout:fixed}
.payroll-table th,.payroll-table td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top;text-align:left}
.payroll-table th{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.03em;background:#F8FAFC}
.payroll-table td{font-size:14px}
.payroll-table .right{text-align:right}
.payroll-staff-wrap{padding:0;overflow:hidden}
.payroll-staff-toolbar{display:flex}
.payroll-staff-toolbar>b{white-space:nowrap}
.payroll-staff-toolbar .table-filter-chip-row{flex-basis:100%;margin-left:0;order:10}
.payroll-staff-table-shell{overflow:auto;background:#fff}
.payroll-staff-table{min-width:980px}
.payroll-staff-table th,.payroll-staff-table td{font-size:13px;line-height:1.28;padding:13px 24px;vertical-align:middle;overflow:hidden;transition:background .15s,color .15s,padding-left .15s,padding-right .15s}
.payroll-staff-table th{font-size:10px;line-height:1.1;padding:9px 24px;font-weight:650}
.payroll-staff-table tbody tr.payroll-staff-row{height:66px;cursor:pointer;transition:background .15s,box-shadow .15s,opacity .15s,transform .15s}
.payroll-staff-table tbody tr.payroll-staff-row:hover{background:var(--selected-bg);box-shadow:inset 0 0 0 1px #D9E3EF;color:var(--green-d)}
.payroll-staff-table tbody tr.payroll-staff-row:hover td{background:var(--selected-bg)}
.payroll-staff-row:hover td:first-child,.payroll-row-dragging td:first-child,.payroll-row-drop-before td:first-child,.payroll-row-drop-after td:first-child{padding-left:34px}
.payroll-staff-row:hover td:last-child,.payroll-row-dragging td:last-child,.payroll-row-drop-before td:last-child,.payroll-row-drop-after td:last-child{padding-right:64px !important}
.payroll-staff-table tbody tr.payroll-row-dragging{opacity:.45;transform:scale(.998)}
.payroll-staff-table tbody tr.payroll-row-drop-before{box-shadow:inset 0 2px 0 var(--green)}
.payroll-staff-table tbody tr.payroll-row-drop-after{box-shadow:inset 0 -2px 0 var(--green)}
.payroll-staff-col-employee{width:300px}
.payroll-staff-col-scope{width:250px}
.payroll-staff-col-amount{width:140px}
.payroll-staff-col-payment{width:auto}
.payroll-staff-employee-cell{position:relative}
.payroll-staff-payment-cell{position:relative !important;padding-right:48px !important;overflow:visible !important}
.payroll-staff-row:hover .payroll-staff-payment-cell,.payroll-row-dragging .payroll-staff-payment-cell,.payroll-row-drop-before .payroll-staff-payment-cell,.payroll-row-drop-after .payroll-staff-payment-cell{padding-right:64px !important}
.payroll-row-drag-handle{position:absolute;right:18px;top:50%;transform:translateY(-50%);width:14px;height:22px;border:0;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;line-height:1;cursor:grab;opacity:0;transition:opacity .12s,color .12s;pointer-events:auto;z-index:6}
.payroll-row-drag-handle::before{content:"☰"}
.payroll-row-drag-handle:hover{color:var(--green-d)}
.payroll-row-drag-handle:active{cursor:grabbing;color:var(--green-d)}
.payroll-staff-row:hover .payroll-row-drag-handle,.payroll-row-dragging .payroll-row-drag-handle,.payroll-row-drop-before .payroll-row-drag-handle,.payroll-row-drop-after .payroll-row-drag-handle{opacity:1}
.payroll-staff-main{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.payroll-staff-row:hover .payroll-staff-main{color:var(--green-d)}
.payroll-staff-sub{font-size:12px;color:var(--muted);line-height:1.2;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}
.payroll-staff-scope{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.payroll-staff-row:hover .payroll-staff-scope{color:var(--green-d)}
.payroll-staff-amount{font-weight:500;white-space:nowrap;color:var(--text);font-variant-numeric:tabular-nums}
.payroll-staff-row:hover .payroll-staff-amount{color:var(--green-d)}
.payroll-staff-table .payroll-payment-summary{display:grid;grid-template-columns:minmax(0,1fr);gap:2px;max-width:100%;font-size:13px;line-height:1.25;font-weight:400;color:var(--text);overflow:hidden}
.payroll-payment-from,.payroll-payment-to{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;min-width:0}
.payroll-payment-from{color:var(--text);font-weight:400}
.payroll-payment-to{color:var(--muted);font-weight:400}
.payroll-payment-flow{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;min-width:0}
.payroll-staff-row:hover .payroll-payment-flow,.payroll-staff-row:hover .payroll-payment-from,.payroll-staff-row:hover .payroll-payment-to{color:var(--green-d)}
.payroll-staff-table th:last-child,.payroll-staff-table td:last-child{position:static !important;right:auto !important;box-shadow:none !important}
.payroll-staff-table td.payroll-staff-payment-cell{position:relative !important}
.payroll-staff-table thead th:last-child{background:#F8FAFC !important}
.payroll-register-table th:nth-child(1){width:30%}
.payroll-register-table th:nth-child(2){width:15%}
.payroll-register-table th:nth-child(3){width:16%}
.payroll-register-table th:nth-child(4){width:29%}
.payroll-register-table th:nth-child(5){width:10%}
.payroll-receiver-account{margin-top:6px;width:100%}
.payroll-actions{display:flex;justify-content:space-between;gap:12px;padding:16px 18px;background:#F8FAFC}
.payroll-template-modal{max-width:760px;border-radius:16px;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(203,217,232,.95);box-shadow:0 22px 60px rgba(15,23,42,.22)}
.payroll-template-modal .modal-head{align-items:center;background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);padding:12px 20px}
.payroll-template-modal .modal-head h3{font-size:22px;line-height:1.2;margin:0;color:#101828}
.payroll-template-modal .modal-head p{margin:5px 0 0;color:var(--muted);font-size:13px;line-height:1.4;max-width:560px}
.payroll-template-modal .modal-close{width:34px;height:34px;border-radius:10px;font-size:22px;color:#7187a4;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.payroll-template-modal .modal-close:hover{background:#eef4fb;color:#31506f}
.payroll-template-modal .modal-body{padding:14px 20px 10px;overflow-y:auto;background:#fbfdff}
.payroll-template-modal .modal-foot{padding:12px 20px;background:#f8fafc;border-top:1px solid #e6edf5}
.payroll-form-section{padding:0 0 12px;margin:0 0 12px;border-bottom:1px solid #e6edf5}
.payroll-form-section:last-child{padding-bottom:0;margin-bottom:0;border-bottom:0}
.payroll-form-section-title{font-weight:800;font-size:14px;color:#10233f;margin-bottom:10px}
.payroll-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px}
.payroll-person-grid{grid-template-columns:minmax(300px,1.35fr) minmax(220px,.85fr);align-items:end}
.payroll-employee-field{grid-column:1;grid-row:1}
.payroll-article-field{grid-column:1;grid-row:2}
.payroll-position-field{grid-column:2;grid-row:1}
.payroll-salary-amount-field{grid-column:2;grid-row:2}
.payroll-salary-amount-field input{min-height:54px!important;font-size:22px!important;font-weight:600!important;letter-spacing:0;color:#061936;padding:8px 16px!important;background:#f7fcfa!important;border-color:#b7dfc4!important;box-shadow:0 0 0 4px rgba(34,197,94,.10),inset 0 0 0 1px rgba(255,255,255,.7)}
.payroll-form-wide{grid-column:1 / -1}
.payroll-payment-summary{line-height:1.45}
.payroll-payment-help{margin:-2px 0 10px;color:#60718a;font-size:13px;line-height:1.4}
.payroll-section-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.payroll-section-row .payroll-form-section-title{margin:0}
.payroll-section-row .btn{min-height:38px;white-space:nowrap}
.payroll-template-payment-lines{display:flex;flex-direction:column;gap:6px}
.payroll-template-payment-head{display:grid;grid-template-columns:minmax(220px,1.25fr) 130px minmax(220px,1.1fr) 36px;gap:8px;align-items:end;padding:0 8px;color:#60718a;font-size:13px;font-weight:800}
.payroll-template-payment-line{display:grid;grid-template-columns:minmax(220px,1.25fr) 130px minmax(220px,1.1fr) 36px;gap:8px;align-items:center;padding:8px 10px;border:1px solid #dfe8f3;border-radius:12px;background:#fff}
.payroll-template-payment-line label{gap:0!important}
.payroll-template-payment-line .btn{min-height:38px;white-space:nowrap}
.payroll-template-payment-line input,.payroll-template-payment-line select{min-height:38px!important;padding:8px 12px!important}
.payroll-payment-amount-field input{text-align:right;font-weight:700!important}
.payroll-payment-remove{width:34px!important;height:34px!important;min-height:34px!important;padding:0!important;border-radius:50%!important;font-size:23px!important;line-height:1!important;display:flex!important;align-items:center!important;justify-content:center!important;color:#d33b3b!important;background:transparent!important;border:0!important}
.payroll-payment-remove:hover{background:#fee2e2!important;color:#b91c1c!important}
.payroll-template-balance{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;padding:9px 10px;border-radius:12px;font-size:13px;line-height:1.35}
.payroll-template-balance:empty{display:none}
.payroll-template-balance div{display:flex;flex-direction:column;gap:2px;min-width:0}
.payroll-template-balance b{font-size:14px;color:#7a3d00}
.payroll-template-balance span{color:#60718a}
.payroll-template-balance .btn{min-height:34px;padding:7px 10px;white-space:nowrap}
.payroll-template-balance.is-warning{border:1px solid #ffd796;background:#fff8e8}
.payroll-template-balance.is-muted{border:1px solid #d8e2ef;background:#f7fbff}
.payroll-template-balance.is-ok{border:1px solid #bfe8cf;background:#f2fbf5}
.payroll-template-balance.is-ok span{color:#14833b}
.payroll-template-receiver select:disabled{background:#f3f6fa;color:#8a9ab0}
.payroll-quick-employee{margin-top:10px;padding:10px;border:1px solid #dfe8f3;border-radius:12px;background:#fff;display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:end}
.payroll-quick-employee>div:first-child{grid-column:1/-1;display:flex;justify-content:space-between;gap:12px;align-items:baseline;color:#10233f}
.payroll-quick-employee>div:first-child span{font-size:12px;color:#60718a;font-weight:600}
.payroll-quick-employee-actions{display:flex;gap:8px;justify-content:flex-end}
.payroll-payment-add{margin-top:10px}
.payroll-payment-empty{padding:10px 12px;border:1px dashed #cbd9e8;border-radius:10px;background:#fff}
.payroll-template-modal label{display:flex;flex-direction:column;gap:6px;min-width:0;color:#60718a;font-size:13px;font-weight:800}
.payroll-template-modal input,.payroll-template-modal select,.payroll-template-modal textarea{box-sizing:border-box;width:100%;min-width:0;border:1px solid #d8e2ef;border-radius:10px;background:#fff;color:#111827;font:inherit;font-weight:600;padding:10px 12px;min-height:42px}
.payroll-template-modal select,.payroll-template-modal option{white-space:nowrap}
.payroll-template-modal textarea{min-height:68px;resize:vertical;line-height:1.45;font-weight:500}
.payroll-template-modal input:focus,.payroll-template-modal select:focus,.payroll-template-modal textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-l)}
.object-constructive-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 10px;max-height:220px;overflow:auto;padding:8px;border:1px solid var(--border);border-radius:8px;background:#fff}
.object-constructive-grid label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#31506f;line-height:1.25}
.object-constructive-grid input{width:auto;min-width:auto}
.op-loan-due-grid{display:grid;grid-template-columns:minmax(150px,.55fr) minmax(220px,1fr);gap:10px;margin-top:8px}
.op-loan-due-grid label{display:block;margin:0 0 5px;color:var(--muted);font-size:12px;font-weight:700}
.op-partner-tax{display:flex;flex-direction:column;gap:8px;padding:10px 12px;border:1px solid #dbe4f0;border-radius:10px;background:#fbfdff}
.op-partner-tax-toggle{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:800;color:#31506f}
.op-partner-tax-toggle input{width:16px;height:16px;accent-color:var(--green)}
.op-partner-tax-grid{display:grid;grid-template-columns:minmax(120px,.45fr) minmax(220px,1fr);gap:10px;align-items:end}
.op-partner-tax-preview{font-size:12px;line-height:1.35;color:#60718a}
.op-partner-tax-preview b{color:#10233f;white-space:nowrap}
@media (max-width:900px){
  .payroll-controls,.payroll-form-grid,.payroll-person-grid,.payroll-template-payment-head,.payroll-template-payment-line{grid-template-columns:1fr}
  .payroll-employee-field,.payroll-article-field,.payroll-position-field,.payroll-salary-amount-field{grid-column:1;grid-row:auto}
  .payroll-template-payment-head{display:none}
  .payroll-quick-employee{grid-template-columns:1fr}
  .payroll-quick-employee>div:first-child{display:block}
  .payroll-actions{flex-direction:column}
  .payroll-section-row{align-items:stretch;flex-direction:column}
  .op-loan-due-grid,.op-partner-tax-grid{grid-template-columns:1fr}
}
