:root{
  --blue:#0057D9;--blue-dark:#0044a8;--blue-soft:#e8f0fe;
  --ink:#16181d;--ink-2:#42474f;--ink-3:#6b7280;
  --line:#e2e5ea;--line-2:#eef0f3;--bg:#f6f7f9;--paper:#fff;
  --warn:#b45309;--warn-bg:#fff7ed;--danger:#b91c1c;
  --r:6px;--r-lg:10px;--mono:'IBM Plex Mono',monospace;--sans:'IBM Plex Sans',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:14px}
code{font-family:var(--mono);font-size:.85em;background:var(--line-2);padding:1px 5px;border-radius:4px}

.btn{border:1px solid var(--line);background:var(--paper);color:var(--ink);padding:8px 14px;border-radius:var(--r);font-weight:500;font-size:13px;transition:.12s}
.btn:hover{border-color:var(--ink-3)}
.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn-ghost:hover{background:var(--line-2)}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-danger{color:var(--danger);border-color:var(--line)}
.btn-danger:hover{background:#fef2f2;border-color:var(--danger)}
.btn:disabled{opacity:.4;cursor:not-allowed}

.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 20%,#eef2f7,transparent 60%),var(--bg)}
.login-card{width:380px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.login-brand{display:flex;align-items:center;gap:13px;margin-bottom:26px}
.logo-mark{background:var(--blue);color:#fff;font-family:var(--mono);font-weight:600;width:42px;height:42px;border-radius:9px;display:grid;place-items:center;font-size:16px}
.logo-mark.sm{width:30px;height:30px;font-size:13px;border-radius:7px}
.login-title{font-size:19px;font-weight:600}
.login-sub{font-size:12.5px;color:var(--ink-3)}
.login-form{display:flex;flex-direction:column;gap:5px}
.login-form label{font-size:12px;font-weight:500;color:var(--ink-2);margin-top:8px}
.login-form input{border:1px solid var(--line);border-radius:var(--r);padding:9px 11px;outline:none}
.login-form input:focus{border-color:var(--blue)}
.login-form .btn-primary{margin-top:14px;padding:10px}
.login-err{color:var(--danger);font-size:12.5px;min-height:16px;margin-top:6px}

.topbar{height:54px;background:var(--paper);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 18px;position:sticky;top:0;z-index:50;gap:12px}
.topbar-left{display:flex;align-items:center;gap:11px}
.topbar-title{font-weight:600;font-size:15px}
.topbar-center{display:flex;gap:8px}
.sel{border:1px solid var(--line);border-radius:var(--r);padding:6px 10px;background:var(--paper);font-size:13px;color:var(--ink)}
.sel:focus{outline:none;border-color:var(--blue)}
.topbar-right{display:flex;align-items:center;gap:10px}
.user-badge{font-size:12.5px;color:var(--ink-2);font-weight:500}

.main{padding:18px}
.view{max-width:100%;margin:0 auto}

.board{display:flex;gap:12px;overflow-x:auto;padding-bottom:10px;align-items:flex-start}
.col{flex:0 0 250px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);min-height:120px}
.col-head{padding:10px 13px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;justify-content:space-between}
.col-head .dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:7px}
.col-name{font-size:12.5px;font-weight:600}
.col-count{font-size:11px;color:var(--ink-3);font-family:var(--mono);background:var(--line-2);padding:1px 7px;border-radius:10px}
.col-body{padding:9px;display:flex;flex-direction:column;gap:8px;min-height:60px}
.col-body.drop-hot{background:var(--blue-soft);border-radius:var(--r)}

.mat-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:10px 11px;cursor:grab;transition:.12s;border-left:3px solid #8b8f98}
.mat-card:hover{border-color:var(--ink-3);box-shadow:0 2px 6px rgba(0,0,0,.05)}
.mat-card.dragging{opacity:.4}
.mat-title{font-size:13px;font-weight:500;line-height:1.35;margin-bottom:8px}
.mat-meta{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.tag{font-size:10.5px;font-family:var(--mono);padding:1px 6px;border-radius:4px;background:var(--line-2);color:var(--ink-2)}
.tag.type{background:var(--blue-soft);color:var(--blue);font-weight:500}
.tag.goal{background:#f3f0ff;color:#6d28d9}
.tag.cross{background:#ecfdf5;color:#047857}
.mat-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--ink-3)}
.avatar{width:20px;height:20px;border-radius:50%;background:var(--blue);color:#fff;font-size:10px;display:inline-grid;place-items:center;font-weight:600}
.ext-flag{font-size:10px;color:var(--warn);background:var(--warn-bg);padding:1px 6px;border-radius:4px;border:1px solid #fed7aa}
.date-chip{font-family:var(--mono);font-size:10.5px}
.date-chip.soon{color:var(--warn)}.date-chip.over{color:var(--danger)}

.modal-overlay{position:fixed;inset:0;background:rgba(20,24,31,.42);display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;z-index:100;overflow-y:auto}
.modal{background:var(--paper);border-radius:var(--r-lg);width:100%;box-shadow:0 12px 40px rgba(0,0,0,.18);animation:pop .14s ease}
@keyframes pop{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.card-modal{max-width:720px}.form-modal{max-width:560px}.trans-modal{max-width:440px}
.modal-head{padding:16px 20px;border-bottom:1px solid var(--line-2);display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.modal-head h2{font-size:16px;font-weight:600;line-height:1.35}
.modal-close{border:none;background:var(--line-2);width:30px;height:30px;border-radius:50%;font-size:18px;color:var(--ink-3);line-height:1}
.modal-close:hover{color:var(--ink)}
.modal-body{padding:18px 20px}
.modal-foot{padding:14px 20px;border-top:1px solid var(--line-2);display:flex;gap:9px;justify-content:flex-end;flex-wrap:wrap}

.status-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 11px;border-radius:20px;color:#fff}
.status-pill .dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.85)}

.route{display:flex;align-items:center;flex-wrap:wrap;gap:0;margin:14px 0 4px}
.route-step{font-size:10.5px;font-family:var(--mono);padding:3px 9px;border-radius:20px;background:var(--line-2);color:var(--ink-3);white-space:nowrap}
.route-step.done{background:#dcfce7;color:#166534}
.route-step.current{background:var(--blue);color:#fff;font-weight:600}
.route-sep{color:var(--line);margin:0 2px;font-size:10px}

.fields{display:grid;grid-template-columns:1fr 1fr;gap:12px 18px;margin-top:16px}
.field{display:flex;flex-direction:column;gap:3px}
.field.full{grid-column:1/-1}
.field label{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.4px}
.field .val{font-size:13.5px}
.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:var(--r);padding:8px 10px;outline:none;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue)}
.field textarea{resize:vertical;min-height:62px}
.chips{display:flex;flex-wrap:wrap;gap:5px}
.checkbox-row{display:flex;align-items:center;gap:7px;font-size:13px;margin:0}
.checkbox-row input{width:auto}

.timeline{margin-top:10px;border-left:2px solid var(--line);padding-left:16px;display:flex;flex-direction:column;gap:13px}
.tl-item{position:relative}
.tl-item::before{content:'';position:absolute;left:-21px;top:4px;width:9px;height:9px;border-radius:50%;background:var(--blue);border:2px solid var(--paper)}
.tl-item.revise::before{background:var(--warn)}
.tl-item.comment::before{background:var(--ink-3)}
.tl-line{font-size:13px}
.tl-arrow{font-family:var(--mono);font-size:11.5px;color:var(--ink-2)}
.tl-note{font-size:12.5px;color:var(--ink-2);margin-top:2px;font-style:italic}
.tl-meta{font-size:11px;color:var(--ink-3);margin-top:2px}

.section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-3);margin:20px 0 4px}
.muted{color:var(--ink-3)}
.empty{text-align:center;color:var(--ink-3);padding:50px 20px;font-size:13.5px}
.revise-tag{font-size:10px;color:var(--warn);font-weight:600;margin-left:4px}
.beacon{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:9px 12px;display:flex;gap:11px;align-items:center;border-left:3px solid #00D45A;margin-bottom:7px}
.beacon.smm{border-left-color:#0891b2}
.beacon .ic{font-size:17px}
.beacon .k{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-3)}
.beacon .m{font-size:11.5px;color:var(--ink-3);margin-top:2px}
.flash{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:8px;font-size:13px;z-index:200;max-width:560px;box-shadow:0 6px 20px rgba(0,0,0,.25);display:none}

/* ===== Слой 2: админка ===== */
.admin-modal{max-width:980px}
.admin-tabs{display:flex;gap:2px;border-bottom:1px solid var(--line-2);padding:0 20px;margin-top:-4px}
.admin-tab{border:none;background:none;padding:12px 16px;font-weight:500;font-size:14px;color:var(--ink-2);border-bottom:2px solid transparent}
.admin-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.admin-body{padding:18px 20px;max-height:70vh;overflow-y:auto}
.atable{width:100%;border-collapse:collapse;font-size:13px}
.atable th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-3);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line-2)}
.atable td{padding:9px 10px;border-bottom:1px solid var(--line-2);vertical-align:top}
.atable tr:hover td{background:var(--line-2)}
.role-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-family:var(--mono);background:var(--blue-soft);color:var(--blue);padding:2px 8px;border-radius:5px;margin:2px 3px 2px 0}
.role-chip.brand{background:#f3f0ff;color:#6d28d9}
.role-chip .rx{cursor:pointer;opacity:.6;font-weight:700}
.role-chip .rx:hover{opacity:1}
.scope-badge{font-size:10px;font-family:var(--mono);padding:1px 6px;border-radius:4px}
.scope-badge.global{background:#ecfdf5;color:#047857}
.scope-badge.brand{background:#f3f0ff;color:#6d28d9}
.sys-badge{font-size:10px;color:var(--ink-3);background:var(--line-2);padding:1px 6px;border-radius:4px}
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;margin-top:8px}
.perm-grp-label{grid-column:1/-1;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-3);margin-top:10px}
.perm-check{display:flex;align-items:center;gap:7px;font-size:12.5px}
.perm-check input{width:auto}
.inactive-row td{opacity:.5}
.mini-btn{font-size:11.5px;padding:4px 9px;border:1px solid var(--line);background:var(--paper);border-radius:5px;color:var(--ink-2)}
.mini-btn:hover{border-color:var(--ink-3)}
.mini-btn.danger{color:var(--danger);border-color:#fecaca}
.rubric-pick{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px;max-height:120px;overflow-y:auto;border:1px solid var(--line);border-radius:var(--r);padding:8px}
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.toolbar h3{font-size:15px}

/* персональные права пользователя */
.uperm-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px solid var(--line-2)}
.uperm-name{font-size:13px}
.uperm-base{font-size:10.5px;font-family:var(--mono);color:var(--ink-3);margin-left:6px;background:var(--line-2);padding:1px 6px;border-radius:4px}
.uperm-seg{display:flex;flex:0 0 auto;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.uperm-seg .seg{border:none;background:var(--paper);padding:5px 10px;font-size:11.5px;color:var(--ink-2);border-right:1px solid var(--line)}
.uperm-seg .seg:last-child{border-right:none}
.uperm-seg .seg.on{background:var(--ink);color:#fff}
.uperm-seg .seg.seg-allow.on{background:#047857}
.uperm-seg .seg.seg-deny.on{background:var(--danger)}

/* справочники (Слой 3a) */
.ref-subnav{display:flex;gap:4px;margin-bottom:14px;flex-wrap:wrap}
.ref-sub{border:1px solid var(--line);background:var(--paper);padding:6px 13px;border-radius:20px;font-size:12.5px;color:var(--ink-2)}
.ref-sub.active{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:500}
.ref-grp-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-3);margin:14px 0 4px}

/* редактор воркфлоу (Слой 3b) */
.wf-hint{font-size:12px;color:var(--ink-3);background:var(--warn-bg);border:1px solid #fed7aa;border-radius:var(--r);padding:8px 11px;margin-bottom:14px}
.wf-stages{display:flex;flex-direction:column;gap:10px}
.wf-stage{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.wf-stage-head{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:var(--paper)}
.wf-stage-name{font-weight:600;font-size:14px;margin-right:6px}
.wf-stage-head code{margin-left:6px}
.wf-stage-actions{display:flex;align-items:center;gap:6px}
.wf-trans-list{background:var(--bg);padding:6px 12px 10px;display:flex;flex-direction:column;gap:4px}
.wf-trans{display:flex;align-items:center;gap:8px;font-size:12.5px;padding:5px 8px;background:var(--paper);border:1px solid var(--line-2);border-radius:5px;flex-wrap:wrap}
.wf-trans.empty-trans{color:var(--ink-3);font-style:italic;justify-content:center;background:transparent;border:1px dashed var(--line)}
.wf-trans-arrow{font-family:var(--mono);font-weight:600;color:var(--blue)}
.wf-trans-label{font-weight:500}
.wf-trans-roles{color:var(--ink-3);font-size:11.5px;margin-left:auto}
.wf-trans-act{display:flex;gap:4px;flex:0 0 auto}
