:root{
  --bg:#0b1220; --bg2:#0f1830; --panel:#121c33; --panel2:#16213d;
  --line:#1f2c49; --line2:#26345a;
  --txt:#e8eefb; --muted:#92a2c4; --muted2:#6c7da3;
  --accent:#1296c4; --accent2:#2db8e0; --accent-soft:#1296c433;
  --green:#16a34a; --green-soft:#16a34a22;
  --amber:#d97706; --amber-soft:#d9770622;
  --red:#dc2626; --red-soft:#dc262622;
  --cyan:#0891b2; --violet:#7c3aed; --pink:#db2777;
  --radius:14px; --radius-sm:10px;
  --shadow:0 10px 30px -12px rgba(0,0,0,.55);
  --shadow-lg:0 24px 60px -18px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:radial-gradient(1200px 700px at 80% -10%,#16264e 0%,transparent 55%),
             radial-gradient(900px 600px at -10% 110%,#10203f 0%,transparent 50%),
             var(--bg);
  color:var(--txt);-webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#27375f;border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-track{background:transparent}
.svg-i{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex:none}
.svg-i.sm{width:15px;height:15px}
.svg-i.lg{width:22px;height:22px}

/* ====== LOGIN ====== */
.login-wrap{min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:24px;overflow-y:auto}
.login-card{width:100%;max-width:920px;margin:auto;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr}
.login-side{padding:42px 38px;background:
  radial-gradient(600px 300px at 110% -20%,#2a4fae55,transparent 60%),
  linear-gradient(160deg,#16224080,#0d1730);border-right:1px solid var(--line);position:relative}
.login-side h1{font-size:30px;font-weight:800;letter-spacing:-.6px;line-height:1.1;margin-top:18px}
.login-side .grad{background:linear-gradient(90deg,#2db8e0,#1296c4);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-side p{color:var(--muted);margin-top:14px;font-size:14.5px;line-height:1.6}
.login-feats{margin-top:26px;display:flex;flex-direction:column;gap:12px}
.login-feat{display:flex;gap:11px;align-items:center;font-size:13.5px;color:#cdd9f2}
.login-feat .fi{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--accent-soft);color:#5fc4e6;flex:none}
.brand{display:flex;align-items:center;gap:11px}
.brand-logo{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,#1296c4,#2db8e0);display:grid;place-items:center;box-shadow:0 8px 22px -8px #1296c4cc}
.brand-name{font-weight:800;font-size:18px;letter-spacing:-.3px}
.brand-sub{font-size:11px;color:var(--muted);letter-spacing:.5px;text-transform:uppercase}
.login-main{padding:40px 36px;min-width:0}
.login-main h2{font-size:20px;font-weight:700}
.login-main .lead{color:var(--muted);font-size:13.5px;margin-top:6px;margin-bottom:22px}
.accounts{display:flex;flex-direction:column;gap:11px}
.acct{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--panel);transition:.16s;text-align:left;width:100%}
.acct:hover{border-color:var(--accent2);transform:translateY(-1px);box-shadow:var(--shadow)}
.acct .av{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:15px;color:#fff;flex:none}
.acct .ai{flex:1;display:flex;flex-direction:column;min-width:0}
.acct .an{font-weight:600;font-size:15px}
.acct .at{font-size:12.5px;color:var(--muted);margin-top:2px}
.acct .ar{font-size:11px;color:#5fc4e6;background:var(--accent-soft);padding:3px 9px;border-radius:20px;font-weight:600}
.acct .go{color:var(--muted2)}
.login-extra{margin-top:18px;padding-top:16px;border-top:1px dashed var(--line);font-size:12px;color:var(--muted2);line-height:1.6}

/* ====== APP SHELL ====== */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#0e1830,#0b1220);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-top{padding:18px 16px 14px;border-bottom:1px solid var(--line)}
.company-pill{margin-top:13px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.company-pill .cn{font-weight:600;font-size:13.5px}
.company-pill .cc{font-size:11.5px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:5px}
.nav{padding:12px 10px;flex:1;overflow-y:auto}
.nav-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted2);padding:12px 12px 6px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);
  font-size:14px;font-weight:500;transition:.13s;width:100%;text-align:left;position:relative}
.nav-item:hover{background:var(--panel);color:var(--txt)}
.nav-item.active{background:linear-gradient(90deg,var(--accent-soft),transparent);color:#fff}
.nav-item.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--accent2)}
.nav-item .badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:20px}
.nav-item .badge.alt{background:var(--amber)}
.side-bottom{padding:12px;border-top:1px solid var(--line)}
.user-chip{display:flex;align-items:center;gap:10px;padding:9px;border-radius:11px;background:var(--panel);border:1px solid var(--line)}
.user-chip .av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;flex:none}
.user-chip .ui{flex:1;min-width:0;display:flex;flex-direction:column}
.user-chip .un{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .ut{font-size:11px;color:var(--muted)}
.user-chip .sw{color:var(--muted2);padding:6px;border-radius:8px}
.user-chip .sw:hover{background:var(--panel2);color:var(--txt)}

/* ====== MAIN ====== */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:62px;display:flex;align-items:center;gap:16px;padding:0 26px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:#0b1220cc;backdrop-filter:blur(10px);z-index:20}
.page-title{font-size:18px;font-weight:700;letter-spacing:-.3px}
.page-sub{font-size:12.5px;color:var(--muted);margin-top:1px}
.topbar .search{margin-left:auto;position:relative;display:flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:8px 12px;width:240px;color:var(--muted)}
.topbar .search input{background:none;border:none;outline:none;color:var(--txt);width:100%;font-size:13.5px}
.flt-search{position:relative;display:flex;align-items:center;gap:9px;background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:8px 13px;color:var(--muted)}
.flt-search input{background:none;border:none;outline:none;color:var(--txt);width:100%;font-size:13.5px;padding:0}
.flt-search:focus-within{border-color:var(--accent2)}
.search-dd{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-width:90vw;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;display:none;max-height:62vh;overflow-y:auto;z-index:40}
.search-dd.open{display:block}
.sd-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:9px 10px 4px;font-weight:700}
.sd-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:8px 10px;border-radius:8px;background:none;border:none;color:var(--txt);cursor:pointer;font-size:13px}
.sd-item:hover{background:var(--bg2)}
.sd-item .sd-main{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sd-item .sd-sub{margin-left:auto;color:var(--muted);font-size:11.5px;white-space:nowrap;flex-shrink:0}
.sd-empty{padding:16px 10px;color:var(--muted);font-size:13px;text-align:center}
.icon-btn{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:var(--muted);
  background:var(--panel);border:1px solid var(--line);position:relative}
.icon-btn:hover{color:var(--txt);border-color:var(--line2)}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--red);border:2px solid var(--panel)}
.icon-btn .notif-badge{position:absolute;top:-5px;right:-5px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid var(--panel)}
.content{padding:24px 26px 60px}
.theme-fab{position:fixed;top:18px;right:18px;z-index:60;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--panel);border:1px solid var(--line);color:var(--muted);box-shadow:var(--shadow)}
.theme-fab:hover{color:var(--txt);border-color:var(--line2)}

/* ====== UI PRIMITIVES ====== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 15px;border-radius:10px;font-size:13.5px;font-weight:600;
  background:var(--panel);border:1px solid var(--line);color:var(--txt);transition:.14s}
.btn:hover{border-color:var(--line2);background:var(--panel2)}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;
  box-shadow:0 8px 20px -8px #1296c4aa}
.btn.primary:hover{filter:brightness(1.07)}
.btn.green{background:linear-gradient(135deg,#1fae53,#27c862);border-color:transparent;box-shadow:0 8px 20px -8px #27c862aa}
.btn.soft{background:var(--accent-soft);color:#7fd0ec;border-color:#1e40af55}
.btn.soft:hover{background:var(--accent-soft);border-color:var(--accent2);filter:brightness(1.12)}
.btn.ghost{background:transparent}
.btn.sm{padding:7px 11px;font-size:12.5px}
.btn.danger{color:#fca5a5;border-color:#5b1d1d;background:#2a1212}
.btn:disabled{opacity:.5;cursor:not-allowed}
.tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px;
  background:var(--panel2);color:var(--muted);border:1px solid var(--line)}
.tag.green{background:var(--green-soft);color:#4ade80;border-color:#16653433}
.tag.amber{background:var(--amber-soft);color:#fbbf24;border-color:#92400e33}
.tag.red{background:var(--red-soft);color:#f87171;border-color:#7f1d1d33}
.tag.blue{background:var(--accent-soft);color:#7fd0ec;border-color:#1e40af33}
.tag.violet{background:#7c3aed22;color:#c4b5fd;border-color:#5b21b633}
.tag.cyan{background:#0891b222;color:#67e8f9;border-color:#155e7533}
.dot-i{width:8px;height:8px;border-radius:50%;display:inline-block}

.cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}
.kpi{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;position:relative;overflow:hidden;transition:.15s}
.kpi:hover{border-color:var(--line2);transform:translateY(-2px)}
.kpi .k-ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;margin-bottom:14px}
.kpi .k-lbl{font-size:12.5px;color:var(--muted);font-weight:500}
.kpi .k-val{font-size:25px;font-weight:800;letter-spacing:-.6px;margin-top:3px}
.kpi .k-sub{font-size:12px;margin-top:8px;display:flex;align-items:center;gap:5px}
.kpi.clickable{cursor:pointer;transition:transform .12s,border-color .12s,box-shadow .12s}
.kpi.clickable:hover{border-color:var(--accent2);transform:translateY(-2px);box-shadow:var(--shadow)}
.up{color:#4ade80}.down{color:#f87171}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel-h{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.panel-h h3{font-size:15px;font-weight:700}
.panel-h .ph-sub{font-size:12px;color:var(--muted)}
.panel-b{padding:18px}
.grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.grid-2b{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.section-gap{margin-top:18px}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted2);
  font-weight:600;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:.1s}
.tbl tbody tr.clickable:hover{background:var(--panel2)}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.avatar-xs{width:28px;height:28px;border-radius:50%;display:inline-grid;place-items:center;font-size:11px;font-weight:700;color:#fff}
.cell-name{display:flex;align-items:center;gap:9px}
.muted{color:var(--muted)}.muted2{color:var(--muted2)}
.mini-bar{height:6px;border-radius:6px;background:var(--line);overflow:hidden;min-width:70px}
.mini-bar>i{display:block;height:100%;border-radius:6px}

/* ====== KANBAN ====== */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px}
.kcol{flex:0 0 290px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;max-height:calc(100vh - 200px)}
.kcol.drop-hot{border-color:var(--accent2);box-shadow:0 0 0 2px var(--accent-soft) inset}
.kcol-h{padding:13px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.kcol-h .kc-name{font-size:13px;font-weight:700}
.kcol-h .kc-count{font-size:11px;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:1px 8px;font-weight:600}
.kcol-h .kc-sum{margin-left:auto;font-size:11.5px;color:var(--muted);font-weight:600}
.kcol-b{padding:11px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;flex:1}
.kcard{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:11px;padding:12px;
  cursor:grab;transition:.13s;border-left:3px solid var(--accent2)}
.kcard:hover{border-color:var(--line2);transform:translateY(-1px);box-shadow:var(--shadow)}
.kcard:active{cursor:grabbing}
.kcard.dragging{opacity:.4}
.kcard .kc-top{display:flex;justify-content:space-between;align-items:start;gap:8px}
.kcard .kc-client{font-size:13.5px;font-weight:600;line-height:1.3}
.kcard .kc-addr{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:4px}
.kcard .kc-sum{font-size:15px;font-weight:800;margin-top:10px;letter-spacing:-.3px}
.kcard .kc-meta{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.kcard .kc-days{margin-left:auto;font-size:11px;color:var(--muted2);display:flex;align-items:center;gap:4px}

/* ====== MEASURE / CALC ====== */
.measure-grid{display:grid;grid-template-columns:1fr 380px;gap:18px;align-items:start}
.constr-list{display:flex;flex-direction:column;gap:12px}
.constr{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.constr-h{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--panel2);border-bottom:1px solid var(--line)}
.constr-h .ci{width:34px;height:34px;border-radius:9px;background:var(--accent-soft);color:#5fc4e6;display:grid;place-items:center;flex:none}
.constr-h .cn{font-weight:600;font-size:13.5px}
.constr-h .cp{margin-left:auto;font-weight:800;font-size:15px}
.constr-body{padding:14px;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.fld{display:flex;flex-direction:column;gap:6px}
.fld.full{grid-column:1/-1}
.fld label{font-size:11.5px;color:var(--muted);font-weight:600}
.fld input,.fld select{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--txt);font-size:13.5px;outline:none}
.fld input:focus,.fld select:focus{border-color:var(--accent2)}
.fld .row2{display:flex;gap:8px;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{padding:7px 12px;border-radius:9px;border:1px solid var(--line);background:var(--bg2);font-size:12.5px;font-weight:600;color:var(--muted);transition:.12s}
.chip.on{background:var(--accent-soft);border-color:var(--accent2);color:#bfdbfe}
.chip:hover{border-color:var(--line2)}
.chips.oneline{flex-wrap:nowrap;overflow-x:auto;gap:5px;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.chips.oneline .chip{flex:0 0 auto;white-space:nowrap;padding:7px 9px;font-size:11.5px}
.extras{display:flex;flex-wrap:wrap;gap:8px}
.ex-toggle{display:flex;align-items:center;gap:8px;padding:8px 11px;border:1px solid var(--line);border-radius:9px;background:var(--bg2);font-size:12.5px;font-weight:600;color:var(--muted)}
.ex-toggle.on{background:var(--green-soft);border-color:#16653455;color:#86efac}
.win-preview{aspect-ratio:1.25;background:linear-gradient(180deg,#0c1426,#0a1120);border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;gap:6px;grid-column:1/-1}
.win-sash{flex:1;border:2px solid #3b5079;border-radius:4px;background:linear-gradient(135deg,#13233f88,#0e1a3088);position:relative;cursor:pointer;transition:.12s}
.win-sash:hover{border-color:#5a7cb8}
.win-sash.sel{border-color:var(--accent2);box-shadow:0 0 0 2px var(--accent-soft) inset}
.win-sash.off{opacity:.45;border-style:dashed}
.sash-no{position:absolute;top:3px;left:5px;font-size:10px;font-weight:700;color:#5a7cb8;pointer-events:none}
.win-sash.sel .sash-no{color:#bfdbfe}
.win-sym{position:absolute;inset:6px;width:calc(100% - 12px);height:calc(100% - 12px);pointer-events:none}
.win-sym.flip{transform:scaleX(-1)}
.win-sym polyline{fill:none;stroke:#5a7cb8;stroke-width:1.6;vector-effect:non-scaling-stroke;stroke-linejoin:round;stroke-linecap:round}
.summary{position:sticky;top:78px}
.sum-line{display:flex;justify-content:space-between;font-size:13px;padding:8px 0;border-bottom:1px solid var(--line);color:var(--muted)}
.sum-line.total{border-bottom:none;font-size:18px;font-weight:800;color:var(--txt);padding-top:14px}
.sum-line .v{color:var(--txt);font-weight:600;font-variant-numeric:tabular-nums}
.kp-doc{background:#fff;color:#1a2233;border-radius:10px;padding:26px 28px;font-size:13px;max-height:62vh;overflow-y:auto}
.kp-doc h2{font-size:18px;color:#0b1220}
.kp-doc .kp-co{display:flex;justify-content:space-between;border-bottom:2px solid #e5e9f0;padding-bottom:14px;margin-bottom:14px}
.kp-doc table{width:100%;border-collapse:collapse;margin:14px 0;font-size:12.5px}
.kp-doc th{background:#f1f4f9;text-align:left;padding:9px 10px;color:#475569;font-size:11px;text-transform:uppercase}
.kp-doc td{padding:9px 10px;border-bottom:1px solid #eef1f6}
.kp-doc .kp-tot{text-align:right;font-size:16px;font-weight:800;color:#0b1220;margin-top:6px}
.kp-doc .kp-pre{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:12px 14px;margin-top:14px;color:#1e3a8a}
.kp-doc td{vertical-align:top}
.kp-doc .doc-req{font-size:12.5px;line-height:1.7;background:#f8fafc;border:1px solid #e5e9f0;border-radius:8px;padding:10px 12px;margin-bottom:4px}
.kp-doc .doc-words{margin-top:10px;font-size:12.5px}
.kp-doc .doc-sign{display:flex;justify-content:space-between;align-items:flex-end;margin-top:26px;font-size:13px}
.kp-doc .doc-stamp{color:#94a3b8}
.kp-doc.doc-contract p{font-size:13px;line-height:1.6;margin:8px 0}
.kp-doc .doc-parties{display:flex;gap:24px;margin-top:20px;font-size:12px;line-height:1.6}
.kp-doc .doc-parties>div{flex:1}

/* ====== MODAL ====== */
.modal-bg{position:fixed;inset:0;background:#04070f99;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;animation:fade .15s}
.modal{width:100%;max-width:620px;min-width:0;max-height:90vh;max-height:90dvh;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line2);border-radius:18px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:pop .18s}
.modal.wide{max-width:780px}
.modal-h{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-h h3{font-size:17px;font-weight:700}
.modal-h .mh-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.modal-h .x{margin-left:auto;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--muted)}
.modal-h .x:hover{background:var(--panel);color:var(--txt)}
.modal-b{padding:20px 22px;overflow-y:auto}
.modal-f{padding:16px 22px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:translateY(12px) scale(.98)}}

.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:12px;padding-bottom:16px;position:relative}
.tl-item::before{content:"";position:absolute;left:9px;top:20px;bottom:-4px;width:2px;background:var(--line)}
.tl-item:last-child::before{display:none}
.tl-dot{width:20px;height:20px;border-radius:50%;flex:none;display:grid;place-items:center;z-index:1}
.tl-c .tl-t{font-size:13px;font-weight:600}
.tl-c .tl-d{font-size:11.5px;color:var(--muted);margin-top:2px}
.tl-item.read{opacity:.5}
.tl-unread{position:absolute;top:2px;right:2px;width:8px;height:8px;border-radius:50%;background:var(--accent2)}

.stat-line{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}
.stat-line:last-child{border-bottom:none}
.empty{text-align:center;padding:50px 20px;color:var(--muted2)}
.empty .svg-i{width:42px;height:42px;margin:0 auto 14px;stroke-width:1.3;opacity:.5}

.tabs{display:flex;gap:4px;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:4px;width:fit-content}
.tab{padding:8px 15px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted)}
.tab.on{background:var(--accent);color:#fff}
.tab:hover:not(.on){color:var(--txt)}

.perm-tbl td .yes{color:#4ade80}.perm-tbl td .no{color:#475569}
.perm-cell{background:none;border:1px solid transparent;cursor:pointer;padding:5px 9px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;min-width:36px;transition:background .12s,border-color .12s}
.perm-cell:hover{background:var(--bg2);border-color:var(--line)}
.perm-cell.on:hover{border-color:var(--green-soft)}
.row-acts{text-align:right;white-space:nowrap}
.row-acts .btn.sm{padding:6px 9px}
.tbl-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl-scroll>.tbl{min-width:600px}
/* склад: обычная высота строк, действия-иконки — чтобы без горизонтального скролла */
.btn.sm.icon{padding:6px}.btn.sm.icon svg{margin:0}
.cat-tbl{table-layout:fixed;width:100%}
.cat-tbl td:first-child{overflow:hidden;text-overflow:ellipsis}
.perm-tbl{min-width:560px}
/* WhatsApp-чат */
.wa-chat{height:min(52vh,440px);overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px;background:var(--bg2)}
.wa-bub{max-width:80%;padding:8px 11px;border-radius:13px;font-size:13px;line-height:1.45;box-shadow:0 1px 2px #0003;word-break:break-word}
.wa-bub.in{align-self:flex-start;background:var(--panel);border:1px solid var(--line);border-bottom-left-radius:4px}
.wa-bub.out{align-self:flex-end;background:linear-gradient(135deg,#15803d,#16a34a);color:#fff;border-bottom-right-radius:4px}
.wa-bub .wa-mt{font-size:10px;opacity:.7;margin-top:3px;text-align:right}
/* совмещённый вид: сделка + чат */
.modal.wide:has(.wa-split){max-width:940px}
.wa-stagebar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--line)}
.wa-split{display:flex;align-items:stretch;min-height:0}
.wa-deal-info{width:290px;flex:none;padding:16px;border-right:1px solid var(--line);overflow-y:auto;max-height:min(62vh,520px)}
.wa-chat-pane{flex:1;min-width:0;display:flex;flex-direction:column}
.wa-compose{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line)}
@media (max-width:700px){
  .wa-split{flex-direction:column}
  .wa-deal-info{width:auto;border-right:none;border-bottom:1px solid var(--line);max-height:210px}
  .wa-chat .wa-chat,.wa-chat-pane .wa-chat{height:min(44vh,320px)}
}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.legend span{display:flex;align-items:center;gap:6px}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast .t{background:var(--panel2);border:1px solid var(--line2);border-radius:12px;padding:13px 18px;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:11px;font-size:13.5px;font-weight:500;animation:toastin .25s;max-width:420px}
.toast .t.ok{border-color:#16653455}
.toast .t .ti{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:none}
@keyframes toastin{from{opacity:0;transform:translateY(14px)}}

.bars{display:flex;flex-direction:column;gap:11px}
.bar-row{display:grid;grid-template-columns:130px 1fr auto;gap:12px;align-items:center;font-size:12.5px}
.bar-row .bl{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{height:24px;background:var(--bg2);border-radius:7px;overflow:hidden;position:relative}
.bar-fill{height:100%;border-radius:7px;display:flex;align-items:center;padding-left:9px;font-size:11px;font-weight:700;color:#fff;min-width:fit-content;transition:width .6s cubic-bezier(.2,.8,.2,1)}
.bar-row .bv{font-weight:700;font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}

.funnel-vis{display:flex;flex-direction:column;gap:7px}
.fv-row{display:flex;align-items:center;gap:12px}
.fv-bar{height:34px;border-radius:8px;display:flex;align-items:center;padding:0 13px;color:#fff;font-weight:700;font-size:13px;
  transition:width .6s cubic-bezier(.2,.8,.2,1);min-width:120px;justify-content:space-between;white-space:nowrap;gap:8px}
.fv-lbl{width:140px;font-size:12.5px;color:var(--muted);text-align:right;flex:none}
.fv-conv{font-size:11px;color:var(--muted2);width:54px;flex:none}

@media (max-width:1100px){.measure-grid{grid-template-columns:1fr}.summary{position:static}.grid-2{grid-template-columns:1fr}}
@media (max-width:920px){.login-card{grid-template-columns:minmax(0,1fr)}.login-side{display:none}}
@media (max-width:480px){.login-main{padding:30px 22px}}
.search-toggle{display:none}
@media (max-width:760px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-260px;z-index:50;transition:.2s;box-shadow:var(--shadow-lg)}
  .sidebar.open{left:0}.content{padding:16px}.topbar{padding:0 14px}.menu-toggle{display:grid!important}
  .search-toggle{display:grid}
  .constr-body{grid-template-columns:1fr}
  .panel-h{flex-wrap:wrap;row-gap:8px}
  .topbar .search{display:none}
  .topbar .search.open{display:flex;position:absolute;top:100%;left:0;right:0;width:auto;margin:0;border-radius:0;border-left:none;border-right:none;z-index:60}
  .topbar .search.open .search-dd{left:0;right:0;width:auto;max-width:none}
  .grid-2b{grid-template-columns:1fr}}
@media (max-width:620px){
  .modal-bg{padding:12px}
  .kp-doc{max-height:none}
  .modal-f{flex-wrap:wrap}
  .modal-f .btn{flex:1 1 140px;justify-content:center;min-width:0}
}
.menu-toggle{display:none}

/* ====== LIGHT THEME ====== */
[data-theme="light"]{
  --bg:#eef1f8; --bg2:#e9eef6; --panel:#ffffff; --panel2:#f6f8fc;
  --line:#e3e8f1; --line2:#cdd8e8;
  --txt:#15233b; --muted:#5c6b86; --muted2:#8a98b2;
  --accent:#1296c4; --accent2:#2db8e0; --accent-soft:#1296c414;
  --green:#16a34a; --green-soft:#16a34a16;
  --amber:#d97706; --amber-soft:#d9770618;
  --red:#dc2626; --red-soft:#dc262614;
  --shadow:0 10px 30px -14px rgba(20,40,80,.18);
  --shadow-lg:0 24px 60px -24px rgba(20,40,80,.28);
}
[data-theme="light"] body{
  background:radial-gradient(1200px 700px at 80% -10%,#dbe7ff 0%,transparent 55%),
             radial-gradient(900px 600px at -10% 110%,#e6edfb 0%,transparent 50%),
             var(--bg);
}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:#c5d0e2}
[data-theme="light"] .login-side{background:
  radial-gradient(600px 300px at 110% -20%,#cfe0ff88,transparent 60%),
  linear-gradient(160deg,#eef3fc,#ffffff)}
[data-theme="light"] .login-feat{color:#33415a}
[data-theme="light"] .sidebar{background:linear-gradient(180deg,#ffffff,#f3f6fc)}
[data-theme="light"] .nav-item.active{color:var(--accent)}
[data-theme="light"] .topbar{background:#ffffffcc}
[data-theme="light"] .btn.danger{color:#b91c1c;border-color:#f3c7c7;background:#fdecec}
[data-theme="light"] .btn.soft{color:#1d4ed8;border-color:#bfdbfe;background:#eff6ff}
[data-theme="light"] .tag.green{color:#15803d}
[data-theme="light"] .tag.amber{color:#b45309}
[data-theme="light"] .tag.red{color:#b91c1c}
[data-theme="light"] .tag.blue{color:#1d4ed8}
[data-theme="light"] .tag.violet{color:#6d28d9}
[data-theme="light"] .tag.cyan{color:#0e7490}
[data-theme="light"] .up{color:#15803d}
[data-theme="light"] .down{color:#dc2626}
[data-theme="light"] .perm-tbl td .yes{color:#15803d}
[data-theme="light"] .perm-tbl td .no{color:#94a3b8}
[data-theme="light"] .constr-h .ci{color:var(--accent)}
[data-theme="light"] .chip.on{color:#1d4ed8}
[data-theme="light"] .ex-toggle.on{color:#15803d;border-color:#16a34a55}
[data-theme="light"] .win-preview{background:linear-gradient(180deg,#eaf2ff,#dbe9ff)}
[data-theme="light"] .win-sash{border-color:#9fb4d6;background:linear-gradient(135deg,#ffffffaa,#e8f1fcaa)}
[data-theme="light"] .win-sym polyline{stroke:#6f88b3}
[data-theme="light"] .modal-bg{background:rgba(30,41,59,.35)}
[data-theme="light"] .toast .t.ok{border-color:#16a34a55}

/* ============ ДОСТУП ПО ССЫЛКЕ · ГЕЙТ + ШАРИНГ ============ */
.gate-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1200px 600px at 50% -10%,var(--panel2),transparent),var(--bg)}
.gate-card{width:100%;max-width:460px;text-align:center;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-lg);padding:40px 34px}
.gate-icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin:0 auto 18px;
  background:var(--accent-soft);color:var(--accent2)}
.gate-icon svg{width:30px;height:30px}
.gate-card h1{font-size:23px;font-weight:800;margin:10px 0 12px;letter-spacing:-.01em}
.gate-card p{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:22px}
.gate-btn{display:inline-flex;align-items:center;gap:9px;padding:12px 20px;border-radius:12px;font-weight:700;font-size:14px;
  background:linear-gradient(135deg,#15803d,#16a34a);color:#fff;box-shadow:0 10px 24px -10px #16a34aaa}
.gate-btn:hover{filter:brightness(1.07)}
.gate-foot{margin-top:24px;padding-top:18px;border-top:1px dashed var(--line);font-size:12px;color:var(--muted2)}

.login-fabs{position:fixed;top:18px;right:18px;z-index:60;display:flex;gap:10px;align-items:center}
.login-fabs .theme-fab{position:static}
.share-fab{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 16px;border-radius:11px;font-weight:700;font-size:13px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:1px solid transparent;box-shadow:var(--shadow)}
.share-fab:hover{filter:brightness(1.08)}
.demo-banner{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:55;display:inline-flex;align-items:center;gap:8px;
  background:var(--panel2);border:1px solid var(--line2);border-radius:30px;padding:8px 16px;font-size:12.5px;color:var(--muted);box-shadow:var(--shadow)}
.demo-banner b{color:var(--txt)}

.share-opts{display:flex;flex-wrap:wrap;gap:8px}
.share-opt{flex:1;min-width:84px;padding:10px 8px;border:1px solid var(--line);border-radius:10px;background:var(--bg2);
  color:var(--muted);font-weight:600;font-size:13px;transition:.15s}
.share-opt:hover{border-color:var(--line2);color:var(--txt)}
.share-opt.on{background:var(--accent-soft);border-color:var(--accent2);color:var(--txt)}
.share-result{grid-column:1/-1;margin-top:6px;padding-top:14px;border-top:1px dashed var(--line);display:flex;flex-direction:column;gap:10px}
.share-result .label{font-size:11.5px;color:var(--muted);font-weight:600}
.share-url{width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:var(--txt);
  font-size:12.5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;resize:none;outline:none;word-break:break-all}
.share-url:focus{border-color:var(--accent2)}
.share-result .btn{justify-content:center}

/* подсветка найденной из поиска карточки/строки */
.flash{animation:flashpulse 2s ease-out}
@keyframes flashpulse{
  0%,55%{box-shadow:0 0 0 3px var(--accent2);background-color:var(--accent-soft)}
  100%{box-shadow:0 0 0 0 rgba(18,150,196,0);background-color:transparent}
}

/* Фото объекта + комментарии в карточке сделки/производства */
.ph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px}
.ph-thumb{position:relative;aspect-ratio:1;border-radius:8px;background-size:cover;background-position:center;cursor:pointer;border:1px solid var(--line)}
.ph-thumb:hover{border-color:var(--accent2)}
.ph-del{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:6px;background:rgba(0,0,0,.55);color:#fff;display:grid;place-items:center;border:none;cursor:pointer}
.cmt-list{display:flex;flex-direction:column}
.cmt{padding:8px 0;border-bottom:1px solid var(--line)}
.cmt:last-child{border-bottom:none}
.cmt-h{font-size:12px;margin-bottom:2px}
.cmt-b{font-size:13px;white-space:pre-wrap;word-break:break-word}
