@font-face{font-family:'Russia';src:url('../fonts/Russia.woff2') format('woff2'),url('../fonts/Russia.woff') format('woff');font-weight:normal;font-style:normal;font-display:swap}
@font-face{font-family:'Russia';src:url('../fonts/Russia-Medium.woff2') format('woff2'),url('../fonts/Russia-Medium.woff') format('woff');font-weight:500;font-style:normal;font-display:swap}
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#edf0f5;--sur:#ffffff;--sur2:#f2f5f9;--brd:#d5dfe9;
  --tx:#2c3d56;--mu:#7d94a6;--ac:#2c3d56;--ac2:#c9a47a;
  --gr:#3d8c6a;--ye:#b8922a;--re:#7d2e2e;--or:#a05030;--bl:#7d94a6;
  --shd:0 2px 12px rgba(44,61,86,.08);--shd2:0 6px 28px rgba(44,61,86,.13)
}
body.dark{
  --bg:#1a2c42;--sur:#243652;--sur2:#2e4268;--brd:#3a5272;
  --tx:#edf0f5;--mu:#8ba4bc;--ac:#c9a47a;--ac2:#2c3d56;
  --shd:0 2px 10px rgba(0,0,0,.28);--shd2:0 6px 24px rgba(0,0,0,.42)
}
body{font-family:'Russia',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--tx);min-height:100vh;transition:background .2s,color .2s}
.header{background:var(--ac);border-bottom:1px solid var(--brd);padding:10px 20px;display:flex;align-items:center;position:sticky;top:0;z-index:100;gap:10px;flex-wrap:wrap}
body.dark .header{background:var(--sur)}
.srch{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:8px;padding:6px 12px;color:#fff;font-size:12px;font-family:inherit;width:220px}
.srch:focus{outline:none;border-color:rgba(255,255,255,.6)}.srch::placeholder{color:rgba(255,255,255,.55)}
body.dark .srch{background:var(--sur2);border-color:var(--brd);color:var(--tx)}
.role-btn{padding:5px 11px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.12);color:#fff;white-space:nowrap}
.role-btn:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.5)}
body.dark .role-btn{border-color:var(--brd);background:var(--sur2);color:var(--tx)}
.h-brand .h-t{font-size:16px;font-weight:500;font-family:'Russia',sans-serif;color:#fff;letter-spacing:.02em}.h-brand .h-s{font-size:11px;color:rgba(255,255,255,.65);margin-top:2px}
body.dark .h-brand .h-t{color:var(--tx)}.body.dark .h-brand .h-s{color:var(--mu)}
.h-stats{display:flex;gap:16px}.stat{text-align:center}.stat-v{font-size:18px;font-weight:700;line-height:1;color:#fff}.stat-l{font-size:10px;color:rgba(255,255,255,.65);margin-top:2px}
body.dark .stat-v{color:var(--tx)}
.nav{display:flex;gap:2px;background:rgba(255,255,255,.12);border-radius:10px;padding:3px}
body.dark .nav{background:var(--sur2)}
.nb{padding:6px 14px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;color:rgba(255,255,255,.7);border:none;background:none;white-space:nowrap}
body.dark .nb{color:var(--mu)}
.nb.on{background:#fff;color:var(--ac)}
body.dark .nb.on{background:var(--ac);color:#fff}
.main{padding:18px 24px}
.shd{font-size:11px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.08em;margin:22px 0 10px;display:flex;align-items:center;gap:8px}
.shd::after{content:'';flex:1;height:1px;background:var(--sur2)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;margin-bottom:8px}
.card{background:var(--sur);border:1px solid var(--brd);border-radius:12px;padding:16px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--cc,var(--ac))}
.card:hover{border-color:var(--cc,var(--ac));transform:translateY(-2px);box-shadow:var(--shd2)}
.card-add{border-style:dashed;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:90px}
.card-add::before{display:none}.card-add:hover{border-color:var(--ac)}.card-add:hover .ca-ic,.card-add:hover .ca-la{color:var(--ac)}
.ca-ic{font-size:20px;color:var(--mu)}.ca-la{font-size:12px;color:var(--mu)}
.cmb{position:absolute;top:12px;right:8px;width:26px;height:26px;border-radius:6px;background:transparent;border:none;color:var(--mu);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:3;opacity:0;line-height:1}
.card:hover .cmb{opacity:1}.cmb:hover{background:var(--sur2);color:var(--tx);opacity:1!important}
.c-head{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;padding-right:26px}
.c-title{font-size:13px;font-weight:600;line-height:1.4;flex:1}
.badge{font-size:10px;padding:2px 7px;border-radius:100px;font-weight:600;white-space:nowrap;flex-shrink:0}
.b-ac{background:rgba(61,140,106,.15);color:#3d8c6a;border:1px solid rgba(61,140,106,.2)}
.b-pl{background:rgba(201,164,122,.15);color:#a07840;border:1px solid rgba(201,164,122,.25)}
.b-bl{background:rgba(125,46,46,.12);color:#7d2e2e;border:1px solid rgba(125,46,46,.2)}
.b-do{background:rgba(125,148,166,.12);color:#7d94a6;border:1px solid rgba(125,148,166,.2)}
.c-pm{font-size:12px;color:var(--mu);margin-bottom:3px;display:flex;align-items:center;gap:6px}
.c-dl{font-size:11px;color:var(--mu);margin-bottom:8px;opacity:.8}
.avatar{width:22px;height:22px;border-radius:50%;background:var(--cc,var(--ac));display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}
.c-tasks{margin-bottom:8px}.ct{display:flex;align-items:center;gap:6px;padding:3px 0;border-bottom:1px solid var(--sur2)}.ct:last-child{border:none}
.ct-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.ct-tx{font-size:11px;color:var(--mu);flex:1;line-height:1.3}.ct-dt{font-size:10px;color:var(--mu);white-space:nowrap}
.c-foot{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--sur2)}
.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{font-size:11px;color:var(--mu);display:flex;align-items:center;gap:3px}
.chip-r{color:var(--re)}.chip-o{color:var(--or)}.c-lnk{font-size:11px;color:var(--ac)}
.ctx-menu{position:fixed;background:var(--sur);border:1px solid var(--brd);border-radius:10px;padding:4px;z-index:600;min-width:185px;box-shadow:0 8px 28px rgba(0,0,0,.5);display:none}
.ctx-i{padding:7px 12px;border-radius:6px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--tx);white-space:nowrap}
.ctx-i:hover{background:var(--sur2)}.ctx-i.danger{color:var(--re)}.ctx-sep{height:1px;background:var(--brd);margin:3px 4px}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:none;align-items:flex-start;justify-content:flex-end}
.overlay.open{display:flex}
.panel{background:var(--sur);width:min(940px,96vw);height:100vh;overflow-y:auto;border-left:1px solid var(--brd);animation:sli .2s ease;display:flex;flex-direction:column}
@keyframes sli{from{transform:translateX(100%)}to{transform:translateX(0)}}
.p-head{background:var(--sur);border-bottom:1px solid var(--brd);padding:16px 24px;position:sticky;top:0;z-index:10;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.p-hl{flex:1;min-width:0}.p-title{font-size:17px;font-weight:700;line-height:1.3;margin-top:4px}
.p-meta{font-size:11px;color:var(--mu);display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px}
.cat-tag{font-size:10px;padding:2px 8px;border-radius:4px;font-weight:600}
.cat-core{background:rgba(44,61,86,.12);color:#2c3d56;border:1px solid rgba(44,61,86,.2)}
.cat-migration{background:rgba(61,140,106,.12);color:#2d6b50;border:1px solid rgba(61,140,106,.2)}
.cat-modernization{background:rgba(201,164,122,.15);color:#8a6030;border:1px solid rgba(201,164,122,.3)}
.cat-neighbor{background:rgba(125,148,166,.12);color:#4d6e84;border:1px solid rgba(125,148,166,.2)}
.close-btn{width:32px;height:32px;border-radius:8px;background:var(--sur2);border:none;color:var(--tx);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.close-btn:hover{background:var(--brd)}
.tabs{display:flex;gap:2px;background:var(--sur2);border-radius:10px;padding:3px;margin:16px 24px 0}
.tab{flex:1;padding:6px 8px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;text-align:center;color:var(--mu);border:none;background:none}
.tab.on{background:var(--sur);color:var(--tx)}
.p-body{padding:18px 24px;flex:1}
.sec{margin-bottom:22px}.s-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.s-title{font-size:12px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.06em}
.desc{font-size:13px;line-height:1.7;color:var(--mu);background:var(--sur2);border-radius:8px;padding:12px 14px}
.tt{width:100%;border-collapse:collapse}.tt th{font-size:11px;font-weight:600;color:var(--mu);padding:7px 10px;text-align:left;border-bottom:1px solid var(--brd)}
.tt td{font-size:12px;padding:8px 10px;border-bottom:1px solid var(--sur2);vertical-align:middle}.tt tr:last-child td{border:none}
.inv-bar{display:flex;align-items:center;gap:6px}.inv-t{height:4px;background:var(--sur2);border-radius:2px;width:52px}.inv-f{height:4px;border-radius:2px;background:var(--ac)}
.rf{color:var(--gr)}.rv{color:var(--re)}.rn{color:var(--mu)}
.tlist{display:flex;flex-direction:column;gap:6px}
.trow{background:var(--sur2);border-radius:8px;padding:9px 12px;display:flex;align-items:center;gap:10px}
.trow.tdone{opacity:.5}.trow-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.trow-inf{flex:1;min-width:0}.trow-ti{font-size:12px;font-weight:500}.trow-me{font-size:11px;color:var(--mu);margin-top:2px}
.trow-r{text-align:right;flex-shrink:0}.trow-dt{font-size:11px;color:var(--mu);white-space:nowrap}
.trow-ac{display:flex;gap:2px;justify-content:flex-end;margin-top:4px}
.sd-tgl{font-size:11px;color:var(--mu);cursor:pointer;padding:6px 0;text-align:center}.sd-tgl:hover{color:var(--tx)}
.kb-wrap{overflow-x:auto;padding-bottom:8px}
.kb-board{display:flex;gap:12px;min-width:max-content}
.kb-col{width:210px;background:var(--sur2);border-radius:10px;padding:10px;display:flex;flex-direction:column;min-height:200px}
.kb-col.dov{outline:2px solid var(--ac);outline-offset:-1px}
.kb-col-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.kb-col-t{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.kb-col-n{font-size:10px;color:var(--mu);background:rgba(255,255,255,.08);border-radius:10px;padding:1px 6px}
.kb-cards{display:flex;flex-direction:column;gap:6px;flex:1;min-height:60px}
.kb-card{background:var(--sur);border:1px solid var(--brd);border-radius:8px;padding:9px;cursor:grab;user-select:none}
.kb-card:active{cursor:grabbing}.kb-card.dragging{opacity:.4}
.kb-card-t{font-size:12px;font-weight:500;line-height:1.4;margin-bottom:4px}.kb-card-m{font-size:10px;color:var(--mu)}
.kb-add-col{width:160px;background:transparent;border:1px dashed var(--brd);border-radius:10px;padding:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--mu);font-size:12px;gap:6px;min-height:80px;flex-shrink:0}
.kb-add-col:hover{border-color:var(--ac);color:var(--ac)}
.blist{display:flex;flex-direction:column;gap:8px}
.bi{background:var(--sur2);border-radius:8px;padding:10px 12px;display:flex;gap:10px;align-items:flex-start}
.bi-bl{border-left:3px solid var(--re)}.bi-es{border-left:3px solid var(--or)}.bi-ri{border-left:3px solid var(--ye)}
.bi-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:4px}
.bi-tag{font-size:10px;padding:1px 6px;border-radius:4px;font-weight:600}
.bi-tag-hi{background:rgba(239,68,68,.15);color:var(--re)}.bi-tag-me{background:rgba(234,179,8,.15);color:var(--ye)}.bi-tag-lo{background:rgba(148,163,184,.15);color:var(--mu)}
.bi-ic{font-size:14px;flex-shrink:0;margin-top:1px}.bi-bd{flex:1}
.bi-tx{font-size:12px;line-height:1.5}.bi-me{font-size:11px;color:var(--mu);margin-top:3px}
.qi{background:rgba(234,179,8,.05);border:1px solid rgba(234,179,8,.2);border-radius:8px;padding:10px 12px;font-size:12px;display:flex;align-items:flex-start;gap:8px}
.qi-t{flex:1;line-height:1.5}
.pd-corr{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;margin-bottom:24px}
.pd-col{min-width:160px;max-width:200px;background:var(--sur);border:1px solid var(--brd);border-radius:10px;padding:12px;flex-shrink:0}
.pd-col-h{font-size:13px;font-weight:700;color:var(--ac);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.pd-gis-i{font-size:11px;color:var(--mu);padding:4px 0;border-bottom:1px solid var(--sur2);display:flex;align-items:center;justify-content:space-between;gap:4px}
.pd-gis-i:last-of-type{border:none}.pd-gis-add{font-size:11px;color:var(--mu);cursor:pointer;padding:4px 0;text-align:center;margin-top:4px}
.pd-gis-add:hover{color:var(--ac)}
.pd-det-t{width:100%;border-collapse:collapse;font-size:12px}
.pd-det-t th{font-size:11px;font-weight:600;color:var(--mu);padding:7px 10px;text-align:left;border-bottom:1px solid var(--brd);background:var(--sur2)}
.pd-det-t td{padding:8px 10px;border-bottom:1px solid var(--sur2);vertical-align:middle}
.pd-det-t tr:last-child td{border:none}
.arch-list{display:flex;flex-direction:column;gap:8px}
.arch-c{background:var(--sur);border:1px solid var(--brd);border-radius:10px;padding:14px;display:flex;align-items:center;gap:12px;opacity:.7}
.arch-inf{flex:1}.arch-ti{font-size:13px;font-weight:600}.arch-me{font-size:11px;color:var(--mu);margin-top:3px}
.dash-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.dash-i{background:var(--sur);border:1px solid var(--brd);border-radius:10px;padding:14px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.dash-n{font-size:13px;font-weight:600}.dash-m{font-size:11px;color:var(--mu);margin-top:2px}
.dpb{margin-bottom:24px;background:var(--sur);border:1px solid var(--brd);border-radius:12px;overflow:hidden}
.dpb-h{padding:14px 18px;border-bottom:1px solid var(--brd);display:flex;align-items:center;gap:10px;background:var(--ac)}
.dpb-ht{font-size:14px;font-weight:700;color:#fff}.dpb-b{padding:16px 18px}
.dpb-h .dpb-pm{font-size:11px;color:var(--ac2);background:rgba(255,255,255,.08);border:1px solid var(--ac2);border-radius:20px;padding:2px 10px;white-space:nowrap}
.ck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px}
.ck-r{display:flex;align-items:center;gap:8px;font-size:12px;padding:5px 8px;border-radius:6px;cursor:pointer}
.ck-r:hover{background:var(--sur2)}.ck-r input{accent-color:var(--ac);cursor:pointer}
.btn{padding:6px 12px;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;border:none;transition:all .15s}
.btn-pr{background:var(--ac);color:#fff}.btn-pr:hover{opacity:.88}
.btn-gh{background:transparent;color:var(--mu);border:1px solid var(--brd)}.btn-gh:hover{background:var(--sur2);color:var(--tx)}
.btn-sm{padding:4px 9px;font-size:11px}.btn-ic{width:26px;height:26px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:6px}
.btn-dn{color:var(--re);border-color:transparent}.btn-dn:hover{background:rgba(239,68,68,.1)}
.add-row{display:flex;align-items:center;gap:6px;padding:7px 10px;background:transparent;border:1px dashed var(--brd);border-radius:8px;color:var(--mu);cursor:pointer;font-size:12px;width:100%;justify-content:center;margin-top:6px}
.add-row:hover{border-color:var(--ac);color:var(--ac)}
.ssel{background:transparent;border:none;font-size:11px;cursor:pointer;padding:0;color:var(--tx)}
.eo{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:400;display:none;align-items:center;justify-content:center}
.eo.open{display:flex}
.ed{background:var(--sur);border:1px solid var(--brd);border-radius:14px;padding:22px;width:min(490px,92vw);max-height:90vh;overflow-y:auto}
.ed h3{font-size:15px;font-weight:600;margin-bottom:16px}
.fg{margin-bottom:12px}.fg label{font-size:11px;color:var(--mu);display:block;margin-bottom:4px}
.fi{width:100%;background:var(--sur2);border:1px solid var(--brd);border-radius:7px;padding:8px 11px;color:var(--tx);font-size:12px;font-family:inherit}
.fi:focus{outline:none;border-color:var(--ac)}.fi-a{resize:vertical;min-height:70px}
.frow{display:flex;gap:10px}.frow .fg{flex:1}.e-ac{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}
.empty{font-size:12px;color:var(--mu);padding:14px;text-align:center}
.vp{display:none}.vp.on{display:block}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--sur)}::-webkit-scrollbar-thumb{background:var(--brd);border-radius:3px}
.grid.dov{outline:2px dashed var(--ac);outline-offset:6px;border-radius:8px;}
.card.cdrag{opacity:.4;}
.gm-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:5px;align-items:start}
.gm-blk{border-radius:8px;overflow:hidden;border:1px solid var(--brd)}
.gm-blk-hidden{opacity:.9}
.gm-fpill-hidden{font-size:9px!important;padding:2px 7px!important;opacity:.75}
.gm-fpill-hidden:hover{opacity:1}
.gm-fpill-hidden.on{opacity:1}
.gdp-textarea-fields{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.gdp-taf{display:flex;flex-direction:column;gap:4px}
.gdp-taf-val{font-size:12px;color:var(--tx);line-height:1.5;background:var(--sur2);border-radius:6px;padding:6px 10px;min-height:22px;white-space:pre-wrap}
.gdp-ita{font-family:inherit;font-size:12px;line-height:1.5;color:var(--tx);background:var(--sur2);border:1px solid transparent;border-radius:6px;padding:6px 10px;width:100%;resize:vertical;transition:border-color .15s,background .15s;box-sizing:border-box}
.gdp-ita:hover:not([readonly]){border-color:var(--brd);background:var(--sur)}
.gdp-ita:focus{outline:none;border-color:var(--ac);background:var(--sur)}
.gdp-ita[readonly]{opacity:.7;cursor:default}
.gm-blk-h{padding:5px 8px;display:flex;align-items:center;justify-content:space-between}
.gm-blk-ht{font-size:10px;font-weight:700;color:#fff}.gm-blk-n{font-size:8px;background:rgba(0,0,0,.25);color:rgba(255,255,255,.85);padding:1px 5px;border-radius:10px}
.gm-blk-b{padding:3px;display:flex;flex-direction:column;gap:2px;min-height:30px;background:var(--sur2)}
body.dark .gm-blk-b{background:rgba(0,0,0,.35)}
.gm-blk.gmdov .gm-blk-b{outline:2px dashed var(--ac);outline-offset:-3px}
.gm-card{border-radius:5px;padding:3px 5px;cursor:grab;user-select:none;border:1px solid var(--brd);position:relative;transition:opacity .15s}
.gm-card:active{cursor:grabbing}.gm-card.gdrag{opacity:.25}
.gm-card.gm-drop-before{box-shadow:0 -3px 0 0 #3b82f6}
.gm-card.gm-drop-after{box-shadow:0 3px 0 0 #3b82f6}
.gm-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1px}
.gm-card-num{font-size:8px;font-weight:700;color:var(--mu)}
body.dark .gm-card-num{color:rgba(255,255,255,.6)}
.gm-card-ac{display:flex;gap:1px;opacity:.45;transition:opacity .15s}
.gm-card:hover .gm-card-ac{opacity:1}
.gm-card-name{font-size:9px;color:var(--tx);font-weight:500;line-height:1.3;margin-bottom:1px}
body.dark .gm-card-name{color:#fff}
.gm-card-contractor{font-size:7.5px;color:var(--mu);line-height:1.3;margin-bottom:1px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
body.dark .gm-card-contractor{color:rgba(255,255,255,.5)}
.gm-badge{font-size:7px;padding:1px 3px;border-radius:3px;background:var(--brd);color:var(--mu);display:inline-block}
body.dark .gm-badge{background:rgba(0,0,0,.3);color:rgba(255,255,255,.7)}
.gm-pl{margin-top:2px;display:flex;align-items:center;gap:2px}
body.dark .gm-pl{color:rgba(255,255,255,.65)}
.gm-pl select{background:var(--sur);border:1px solid var(--brd);color:var(--tx);font-size:7px;border-radius:3px;padding:1px 2px;cursor:pointer;width:100%}
body.dark .gm-pl select{background:rgba(0,0,0,.3);border-color:rgba(255,255,255,.2);color:#fff}
.gm-add{text-align:center;padding:2px;font-size:9px;color:var(--mu);cursor:pointer;border:1px dashed var(--brd);border-radius:4px;margin-top:2px}
body.dark .gm-add{color:rgba(255,255,255,.4);border-color:rgba(255,255,255,.15)}
.gm-add:hover{color:var(--ac);border-color:var(--ac)}
/* Gantt drag */
.gantt-bar{position:absolute;height:100%;border-radius:3px;opacity:.85;display:flex;align-items:center;padding:0 10px;cursor:grab;user-select:none;overflow:visible}
.gantt-bar:active{cursor:grabbing}.gantt-bar.gdrag{opacity:1}
.gantt-hdl{position:absolute;top:0;bottom:0;width:7px;cursor:ew-resize;z-index:2;background:rgba(255,255,255,.2)}
.gantt-hdl:hover{background:rgba(255,255,255,.4)}.gantt-hdl-l{left:0;border-radius:3px 0 0 3px}.gantt-hdl-r{right:0;border-radius:0 3px 3px 0}
.gantt-tl{flex:1;height:24px;background:var(--sur2);border-radius:3px;position:relative}
/* Comments */
.comment{background:var(--sur2);border-radius:10px;padding:11px 13px;margin-bottom:8px}
.comment.archived{opacity:.5}
.comment-hd{display:flex;align-items:center;gap:7px;margin-bottom:6px;flex-wrap:wrap}
.comment-author{font-size:12px;font-weight:600}
.comment-role{font-size:10px;color:var(--mu);background:var(--sur);border-radius:4px;padding:1px 6px}
.comment-date{font-size:11px;color:var(--mu)}
.comment-ac{display:flex;gap:3px;margin-left:auto}
.comment-text{font-size:12px;line-height:1.6}
.comment-replies{margin-top:8px;padding-left:12px;border-left:2px solid var(--brd);display:flex;flex-direction:column;gap:6px}
.cmreply{background:var(--sur);border-radius:8px;padding:9px 11px}
/* Admin */
.adm-card{background:var(--sur);border:1px solid var(--brd);border-radius:12px;padding:18px;margin-bottom:12px}
.adm-title{font-size:13px;font-weight:700;color:var(--tx)}
.adm-sub{font-size:11px;color:var(--mu);margin-top:2px}
.adm-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:14px}
.adm-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--sur2);border:1px solid var(--brd);color:var(--mu);font-size:11px;font-weight:700;border-radius:100px;padding:2px 8px;white-space:nowrap;flex-shrink:0}
.adm-sect{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--mu);margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--brd)}
.adm-role-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--brd);border-radius:7px;background:var(--sur2)}
.adm-cfg-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.adm-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:14px}
.adm-stat-card{background:var(--sur);border:1px solid var(--brd);border-radius:10px;padding:12px 8px;text-align:center}
.adm-stat-v{font-size:22px;font-weight:800;line-height:1.1}
.adm-stat-l{font-size:10px;color:var(--mu);margin-top:3px;font-weight:500}
.adm-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:860px){.adm-stats{grid-template-columns:repeat(3,1fr)}.adm-grid{grid-template-columns:1fr}}
.pin-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:12px}
.pin-lbl{flex:1;color:var(--mu)}.pin-dot{font-family:monospace;background:var(--sur2);padding:3px 10px;border-radius:5px;letter-spacing:3px}
/* Card inline comments */
.card-cmt{border-top:1px solid var(--sur2);margin-top:10px;padding-top:8px}
.card-cmt-hd{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--mu);cursor:pointer;user-select:none;padding:2px 0}
.card-cmt-hd:hover{color:var(--ac)}
.card-cmt-hd .cch-ic{font-size:12px}
.card-cmt-hd .cch-cnt{flex:1}
.card-cmt-hd .cch-arr{font-size:9px;transition:transform .15s}
.card-cmt-hd.open .cch-arr{transform:rotate(180deg)}
.card-cmt-body{margin-top:8px;display:none}
.cc-item{padding:6px 0;border-bottom:1px solid var(--sur2);font-size:11px;line-height:1.4}
.cc-item:last-of-type{border:none}
.cc-meta{display:flex;align-items:center;gap:5px;margin-bottom:2px;flex-wrap:wrap}
.cc-author{font-weight:600;font-size:11px;color:var(--tx)}
.cc-rb{font-size:9px;background:var(--sur2);color:var(--mu);border-radius:3px;padding:1px 5px;flex-shrink:0}
.cc-date{font-size:10px;color:var(--mu)}
.cc-text{color:var(--mu);font-size:11px;padding-left:2px}
.cc-showmore{font-size:11px;color:var(--ac);cursor:pointer;padding:4px 0;text-align:center;border-bottom:1px solid var(--sur2);margin-bottom:4px}
.cc-showmore:hover{opacity:.75}
.cc-inp-row{display:flex;gap:5px;align-items:flex-end;margin-top:8px}
.cc-inp{flex:1;resize:none;min-height:34px;max-height:80px;font-size:11px;padding:6px 8px;overflow:hidden}
.cc-send{height:34px;padding:0 10px;font-size:12px;flex-shrink:0}
/* Watermark */
#wm{position:fixed;right:-60px;bottom:80px;pointer-events:none;z-index:0;user-select:none;opacity:.045;transform:rotate(-8deg);transition:opacity .3s}
body.dark #wm{opacity:.06}
@media(max-width:700px){.grid{grid-template-columns:1fr}.h-stats{display:none}}
@media print{
  body:not(.pgis) .header,body:not(.pgis) button,body:not(.pgis) .nb,body:not(.pgis) .cmb,
  body:not(.pgis) .ctx-menu,body:not(.pgis) .overlay,body:not(.pgis) .eo,body:not(.pgis) .add-row,
  body:not(.pgis) .shd,body:not(.pgis) #vp-projects,body:not(.pgis) #vp-archive,
  body:not(.pgis) #vp-gismap,body:not(.pgis) #vp-admin{display:none!important}
  body:not(.pgis) #vp-dashboards{display:block!important}
  body:not(.pgis){background:#fff;color:#000}
  .dpb{break-inside:avoid;margin-bottom:16px;border:1px solid #ccc}
  .dpb-h,.dpb-b,.desc,.trow,.bi,.qi{color:#000;background:#fff}
  body.pgis>*{display:none!important}
  body.pgis #vp-gismap{display:block!important}
  body.pgis .gm-add,body.pgis .gm-card-ac,body.pgis button{display:none!important}
  body.pgis .gm-wrap{grid-template-columns:repeat(4,1fr)!important;gap:6px}
  body.pgis .gm-blk-b{background:#dde4ef!important}
  body.pgis .gm-card{background:#c8d4e8!important;border-color:#93a3b8!important}
  body.pgis .gm-card-name{color:#1e293b!important}
  body.pgis .gm-badge{background:#94a3b8!important;color:#fff!important}
  body.pgis{background:#fff}
}
/* ── GIS card indicator ── */
.gm-ind{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0;border:1px solid rgba(0,0,0,.18);vertical-align:middle;cursor:pointer}
.gm-ind-wrap{display:inline-flex;align-items:center;gap:2px;position:relative}
.gm-ind-picker{display:none;position:absolute;top:12px;right:0;background:var(--sur);border:1px solid var(--brd);border-radius:6px;padding:4px 5px;z-index:50;flex-direction:row;gap:4px;box-shadow:0 3px 10px rgba(0,0,0,.18);white-space:nowrap}
.gm-ind-picker.open{display:flex}
.gm-inp-opt{width:11px;height:11px;border-radius:50%;cursor:pointer;border:1px solid rgba(0,0,0,.18);flex-shrink:0;transition:transform .1s}
.gm-inp-opt:hover{transform:scale(1.25)}
body.dark .gm-ind-picker{background:var(--sur2)}
.gm-ind-q{font-size:8px;color:var(--mu);cursor:pointer;border:1px solid var(--brd);border-radius:50%;width:11px;height:11px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;line-height:1}
#gm-ind-tip{position:fixed;display:none;z-index:2000;background:rgba(24,36,54,.96);color:#f0f4f8;border-radius:9px;padding:9px 13px;font-size:11px;line-height:1.75;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.35);max-width:300px;white-space:nowrap}
#gm-ind-tip div{display:flex;align-items:center;gap:6px}
#gm-ind-tip .tip-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.2)}
/* ── GIS card Поручение ГДЮ ── */
.gm-pouch{display:flex;align-items:center;gap:2px;margin-top:2px}
.gm-pouch-sel{font-size:7px;background:var(--sur);border:1px solid var(--brd);color:var(--tx);border-radius:3px;padding:1px 2px;cursor:pointer;flex:1;min-width:0}
body.dark .gm-pouch-sel{background:rgba(0,0,0,.3);border-color:rgba(255,255,255,.2);color:#fff}
.gm-pl-sel{font-size:7px;background:var(--sur);border:1px solid var(--brd);color:var(--tx);border-radius:3px;padding:1px 2px;cursor:pointer;flex-shrink:0;width:48px}
body.dark .gm-pl-sel{background:rgba(0,0,0,.3);border-color:rgba(255,255,255,.2);color:#fff}
/* ── GIS card comment ── */
.gm-cmt{margin-top:2px}
.gm-cmt-row{display:flex;align-items:center;gap:2px}
.gm-cmt-txt{flex:1;font-size:8px;color:var(--mu);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0;line-height:1.3;cursor:default}
.gm-cmt-empty{color:var(--brd);font-style:italic}
.gm-cmt-arr{cursor:pointer;color:var(--mu);font-size:7px;flex-shrink:0;padding:0 1px;line-height:1}
.gm-cmt-arr:hover{color:var(--tx)}
.gm-cmt-edit{cursor:pointer;color:var(--mu);font-size:9px;opacity:0;transition:opacity .1s;padding:0 1px;flex-shrink:0;line-height:1;background:none;border:none}
.gm-card:hover .gm-cmt-edit{opacity:1}
.gm-cmt-edit:hover{color:var(--ac)}
.gm-cmt-full{display:none;font-size:8px;color:var(--mu);margin-top:2px;padding-top:2px;border-top:1px solid var(--brd);line-height:1.4;word-break:break-word}
.gm-cmt-full.open{display:block}
/* ── Quick task add ── */
.quick-task-row{display:flex;gap:6px;align-items:center;margin-top:8px;padding-top:7px;border-top:1px dashed var(--brd);flex-wrap:wrap}
.quick-task-inp{flex:2;min-width:120px;background:var(--sur2);border:1px solid var(--brd);border-radius:6px;padding:5px 9px;font-size:11px;color:var(--tx);font-family:inherit}
.quick-task-inp:focus{outline:none;border-color:var(--ac)}
.quick-task-owner{flex:1;min-width:80px;background:var(--sur2);border:1px solid var(--brd);border-radius:6px;padding:5px 9px;font-size:11px;color:var(--tx);font-family:inherit}
.quick-task-owner:focus{outline:none;border-color:var(--ac)}
.quick-task-btn{padding:4px 10px;font-size:11px;border-radius:6px;background:var(--ac);color:#fff;border:none;cursor:pointer;flex-shrink:0;font-family:inherit}
.quick-task-btn:hover{opacity:.85}
/* ── GIS Detail Drawer ── */
.gm-dp-ov{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:200;display:none;cursor:pointer}
.gm-dp-ov.open{display:block}
.gm-dp{position:fixed;right:0;top:0;bottom:0;width:min(760px,97vw);background:var(--sur);box-shadow:-4px 0 28px rgba(0,0,0,.22);z-index:201;display:flex;flex-direction:column;transform:translateX(102%);transition:transform .22s cubic-bezier(.4,0,.2,1)}
.gm-dp.open{transform:none}
.gm-dp-hd{padding:16px 16px 12px;flex-shrink:0}
.gm-dp-pm{padding:8px 16px;border-bottom:1px solid var(--brd);border-top:1px solid var(--brd);background:var(--sur2);display:flex;align-items:center;gap:10px;flex-shrink:0;min-height:34px}
.gm-dp-pm-lbl{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--mu);white-space:nowrap}
.gm-dp-pm-val{font-size:13px;font-weight:600;color:var(--tx);flex:1}
.gm-dp-pm-empty{font-size:12px;color:var(--mu);font-style:italic;flex:1}
.gm-dp-pm-edit{font-size:10px;color:var(--ac);cursor:pointer;padding:2px 6px;border-radius:4px;background:none;border:none;font-family:inherit;opacity:.7}
.gm-dp-pm-edit:hover{opacity:1;background:var(--ac2)}
.gm-dp-htop{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.gm-dp-num{font-size:11px;color:var(--mu);margin-bottom:3px}
.gm-dp-name{font-size:15px;font-weight:700;color:var(--tx);line-height:1.3}
.gm-dp-meta{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}
.gm-dp-tabs{display:flex;border-bottom:1px solid var(--brd);flex-shrink:0}
.gdp-tab{padding:8px 14px;font-size:12px;cursor:pointer;background:none;border:none;color:var(--mu);font-family:inherit;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s}
.gdp-tab.on{color:var(--ac);border-bottom-color:var(--ac);font-weight:600}
.gdp-tab:hover:not(.on){color:var(--tx)}
.gm-dp-body{flex:1;overflow-y:auto;padding:14px 16px}
.gdp-sh{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mu);margin:14px 0 6px}
.gdp-sh:first-child{margin-top:0}
.gdp-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--sur2)}
.gdp-row:last-child{border-bottom:none}
.gdp-empty{font-size:11px;color:var(--mu);padding:4px 0;font-style:italic}
.gdp-add{font-size:11px;color:var(--ac);cursor:pointer;margin-top:5px;display:inline-flex;align-items:center;gap:3px}
.gdp-add:hover{text-decoration:underline}
.gdp-task-row{display:flex;align-items:center;gap:5px;padding:4px 0;border-bottom:1px solid var(--sur2)}
.gdp-task-row:last-child{border-bottom:none}
.gdp-task-ti{flex:1;font-size:12px;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gdp-task-me{font-size:10px;color:var(--mu);white-space:nowrap;flex-shrink:0}
.gdp-blocker{display:flex;gap:8px;padding:6px 0;border-bottom:1px solid var(--sur2)}
.gdp-blocker:last-child{border-bottom:none}
.gdp-bl-tx{flex:1;font-size:12px;color:var(--tx)}
.gdp-bl-me{font-size:10px;color:var(--mu);margin-top:2px}
.gdp-gantt-row{display:flex;align-items:center;margin-bottom:5px;gap:6px}
.gdp-gantt-lbl{width:130px;font-size:10px;color:var(--tx);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}
.gdp-gantt-tl{flex:1;height:13px;position:relative;background:var(--sur2);border-radius:3px;overflow:hidden}
.gdp-gantt-bar{position:absolute;height:100%;border-radius:3px;min-width:3px}
/* ── GIS Filter Bar (compact strip) ── */
.gm-fb{display:flex;align-items:center;background:var(--sur);border:1px solid var(--brd);border-radius:10px;padding:5px 10px;margin-bottom:12px;min-height:38px;gap:0}
.gm-fb-scroll{flex:1;display:flex;align-items:center;overflow-x:auto;min-width:0}
.gm-fb-scroll::-webkit-scrollbar{height:3px}.gm-fb-scroll::-webkit-scrollbar-thumb{background:var(--brd);border-radius:2px}
.gm-fsep{width:1px;height:16px;background:var(--brd);flex-shrink:0;margin:0 10px}
.gm-fq{background:none;border:none;font-size:12px;color:var(--tx);font-family:inherit;width:160px;outline:none;padding:2px 4px}
.gm-fq::placeholder{color:var(--mu)}
.gm-fgrp{display:inline-flex;align-items:center;gap:5px;flex-shrink:0}
.gm-fglbl{font-size:9px;color:var(--mu);font-weight:700;letter-spacing:.06em;flex-shrink:0;text-transform:uppercase;padding-right:2px}
.gm-fpill{padding:3px 10px;border-radius:100px;font-size:11px;border:1px solid transparent;background:var(--sur2);color:var(--mu);cursor:pointer;transition:background .1s,color .1s;white-space:nowrap;font-family:inherit;line-height:1.5}
.gm-fpill.on{background:var(--ac);color:#fff}
.gm-fpill:hover:not(.on){background:var(--brd);color:var(--tx)}
.gm-findpill{display:inline-flex;align-items:center;gap:4px}
.gm-findpill .gm-ind-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.gm-fright{margin-left:auto;display:inline-flex;align-items:center;gap:8px;flex-shrink:0;padding-left:10px}
.gm-fcount{font-size:11px;color:var(--mu);background:var(--sur2);border-radius:100px;padding:2px 8px;white-space:nowrap}
.gm-fclear2{font-size:11px;color:var(--mu);cursor:pointer;background:none;border:1px solid var(--brd);border-radius:100px;font-family:inherit;padding:2px 9px;transition:all .1s}
.gm-fclear2:hover{color:var(--ac);border-color:var(--ac)}
.gm-fpill-none.on{background:var(--or);color:#fff}
/* ── Settings / Advanced Search button ── */
.gm-set-btn{position:relative;height:30px;padding:0 10px;border-radius:7px;border:1px solid var(--brd);background:none;color:var(--mu);cursor:pointer;display:inline-flex;align-items:center;gap:5px;font-size:12px;font-family:inherit;font-weight:500;transition:background .1s,color .1s,border-color .1s;flex-shrink:0;white-space:nowrap}
.gm-set-btn.on{background:var(--ac);color:#fff;border-color:var(--ac)}
.gm-set-btn:hover:not(.on){background:var(--sur2);color:var(--tx)}
.gm-set-btn::after{content:'Расширенный поиск';position:absolute;right:0;top:calc(100% + 6px);background:rgba(24,36,54,.94);color:#f0f4f8;font-size:11px;white-space:nowrap;padding:5px 10px;border-radius:7px;pointer-events:none;opacity:0;transition:opacity .15s;z-index:100}
.gm-set-btn:hover::after{opacity:1}
/* ── Advanced Search Modal ── */
.gm-adv-ov{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:350;display:none;align-items:flex-start;justify-content:center;padding-top:72px}
.gm-adv-ov.open{display:flex}
.gm-adv-modal{background:var(--sur);border:1px solid var(--brd);border-radius:14px;width:min(720px,96vw);max-height:82vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.32);animation:sli-down .17s ease}
@keyframes sli-down{from{transform:translateY(-10px);opacity:.2}to{transform:none;opacity:1}}
.gm-adv-mhd{padding:16px 20px;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.gm-adv-mbody{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}
.gm-adv-mft{padding:12px 20px;border-top:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--sur2)}
.gm-adv-sec{display:flex;flex-direction:column;gap:7px}
.gm-adv-sch{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--mu);padding-bottom:5px;border-bottom:1px solid var(--brd)}
.gm-adv-chips{display:flex;flex-wrap:wrap;gap:5px}
.gm-adv-sinp{width:100%;background:var(--sur2);border:1px solid var(--brd);border-radius:8px;padding:9px 14px;font-size:13px;color:var(--tx);font-family:inherit;outline:none}
.gm-adv-sinp:focus{border-color:var(--ac)}
.gm-adv-sinp.active{border-color:var(--ac);background:var(--sur)}
.gm-adv-row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.gm-adv-row3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gm-adv-fgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:10px}
.gm-adv-fg{display:flex;flex-direction:column;gap:4px}
.gm-adv-fl{font-size:11px;color:var(--mu)}
.gm-adv-inp{width:100%;background:var(--sur2);border:1px solid var(--brd);border-radius:6px;padding:6px 10px;font-size:12px;color:var(--tx);font-family:inherit;outline:none}
.gm-adv-inp:focus{border-color:var(--ac)}
.gm-adv-inp.active{border-color:var(--ac);background:rgba(44,61,86,.06)}
body.dark .gm-adv-inp.active{background:rgba(201,164,122,.08)}
.gm-adv-tags{display:flex;flex-wrap:wrap;gap:5px}
.gm-adv-tag{display:inline-flex;align-items:center;gap:4px;background:var(--ac);color:#fff;border-radius:100px;padding:3px 8px 3px 11px;font-size:11px}
.gm-adv-tag-x{cursor:pointer;font-size:13px;line-height:1;opacity:.7;transition:opacity .1s;padding:0 2px}
.gm-adv-tag-x:hover{opacity:1}
@media(max-width:600px){.gm-adv-row2,.gm-adv-row3{grid-template-columns:1fr}.gm-adv-ov{padding-top:0;align-items:flex-end}.gm-adv-modal{border-radius:14px 14px 0 0;max-height:92vh;width:100%}}
/* ── PDF Constructor Modal ── */
.pdf-ov{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:500;display:none;align-items:center;justify-content:center}
.pdf-ov.open{display:flex}
.pdf-modal{background:var(--sur);border-radius:14px;width:min(700px,95vw);max-height:88vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.35)}
.pdf-mhd{padding:16px 22px;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.pdf-mhdt{font-size:15px;font-weight:700}
.pdf-mbody{padding:18px 22px;overflow-y:auto;flex:1;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pdf-msec{background:var(--sur2);border:1px solid var(--brd);border-radius:10px;padding:14px}
.pdf-mfull{grid-column:1/-1}
.pdf-msh{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--mu);margin-bottom:10px}
.pdf-mchk{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.pdf-crow{display:flex;align-items:center;gap:7px;padding:3px 0;cursor:pointer;border-radius:5px}
.pdf-crow:hover{background:var(--brd)}
.pdf-crow label{font-size:12px;cursor:pointer;flex:1;padding:0 4px}
.pdf-crow input[type=checkbox]{cursor:pointer;accent-color:var(--ac);width:14px;height:14px;flex-shrink:0}
.pdf-selall{font-size:11px;color:var(--ac);cursor:pointer;background:none;border:none;font-family:inherit;padding:0 0 8px}
.pdf-selall:hover{text-decoration:underline}
.pdf-mft{display:flex;gap:10px;align-items:center;border-top:1px solid var(--brd);padding:14px 22px;flex-shrink:0}
.pdf-prev{font-size:11px;color:var(--mu);flex:1}
.pdf-swatch{width:12px;height:12px;border-radius:3px;display:inline-block;flex-shrink:0;vertical-align:middle;margin-right:4px}
/* ── Search Overlay ── */
.srch-wrap{position:relative;display:inline-block}
.srch-ov{position:absolute;top:calc(100% + 5px);right:0;width:380px;background:var(--sur);border:1px solid var(--brd);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.2);z-index:400;max-height:70vh;overflow-y:auto;display:none}
.srch-ov.open{display:block}
.srch-ovs{padding:3px 0}
.srch-ovsh{font-size:10px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.06em;padding:7px 12px 3px}
.srch-ovit{padding:6px 12px;cursor:pointer;display:flex;align-items:center;gap:8px}
.srch-ovit:hover{background:var(--sur2)}
.srch-ovitico{font-size:13px;width:18px;text-align:center;flex-shrink:0}
.srch-ovitx{font-size:12px;color:var(--tx);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.srch-ovitsub{font-size:10px;color:var(--mu);white-space:nowrap;flex-shrink:0;max-width:100px;overflow:hidden;text-overflow:ellipsis}
.srch-ov-sep{height:1px;background:var(--brd);margin:2px 8px}
.srch-ov-empty{padding:16px 12px;text-align:center;font-size:12px;color:var(--mu)}
/* ── Kanban edit ── */
.kb-card-ac{display:flex;gap:3px;margin-top:5px;justify-content:flex-end;opacity:0;transition:opacity .12s}
.kb-card:hover .kb-card-ac{opacity:1}
.gm-card-name{font-size:11px;font-weight:600;color:var(--tx);cursor:pointer;margin:2px 0 3px;line-height:1.3}
.gm-card-name:hover{color:var(--ac)}
/* ── GIS Detail: inline field editing ── */
.gdp-fld{display:flex;align-items:flex-start;gap:8px;padding:7px 0;border-bottom:1px solid var(--sur2)}
.gdp-fld:last-child{border-bottom:none}
.gdp-flbl{font-size:11px;color:var(--mu);width:130px;flex-shrink:0;padding-top:4px}
.gdp-fval{flex:1;font-size:12px;color:var(--tx)}
.gdp-finp{flex:1;background:var(--sur2);border:1px solid var(--brd);border-radius:6px;padding:5px 8px;font-size:12px;color:var(--tx);font-family:inherit;outline:none}
.gdp-finp:focus{border-color:var(--ac)}
.gdp-fsel{flex:1;background:var(--sur2);border:1px solid var(--brd);border-radius:6px;padding:4px 8px;font-size:12px;color:var(--tx);font-family:inherit;outline:none}
.gdp-fsel:focus{border-color:var(--ac)}
.gdp-emode .gdp-fval{display:none}.gdp-emode .gdp-finp,.gdp-emode .gdp-fsel{display:block}
.gdp-finp,.gdp-fsel{display:none}
.gdp-ebar{display:flex;gap:6px;align-items:center;padding:12px 0 4px;border-top:1px solid var(--brd);margin-top:6px}
/* ── GIS Detail: Kanban board ── */
.gdp-kb{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px}
.gdp-kb::-webkit-scrollbar{height:4px}.gdp-kb::-webkit-scrollbar-thumb{background:var(--brd);border-radius:2px}
.gdp-kbc{flex:0 0 160px;background:var(--sur2);border-radius:8px;padding:8px}
.gdp-kbc-h{font-size:11px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:5px}
.gdp-kbc-n{font-size:10px;color:var(--mu);background:var(--sur);border-radius:100px;padding:1px 6px}
.gdp-kbcard{background:var(--sur);border:1px solid var(--brd);border-radius:6px;padding:8px;margin-bottom:6px;cursor:grab;font-size:11px;transition:box-shadow .1s}
.gdp-kbcard.dragging{opacity:.5}
.gdp-kbcard:hover{box-shadow:0 2px 8px rgba(0,0,0,.1)}
.gdp-kbcard-t{font-size:12px;font-weight:600;color:var(--tx);line-height:1.3;margin-bottom:3px}
.gdp-kbcard-m{font-size:10px;color:var(--mu)}
.gdp-kbc.kbdov{background:var(--brd)}
.gdp-kbadd{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--mu);cursor:pointer;padding:4px 2px;border-radius:5px}
.gdp-kbadd:hover{color:var(--ac)}
/* ── GIS Detail: interactive Gantt ── */
.gdp-gantt-bar{cursor:col-resize;user-select:none}
.gdp-gantt-bar:active{opacity:.85}
.gdp-gantt-tl{cursor:crosshair}
/* ── GIS Detail: info tab 2-col layout ── */
.gdp-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.gdp-info-grid .gdp-fld{border-bottom:1px solid var(--sur2)}
/* ── Dashboard Widgets ── */
.wg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:14px;padding:4px 0 24px}
.wg-card{background:var(--sur);border:1px solid var(--brd);border-radius:14px;overflow:hidden;transition:box-shadow .15s,transform .15s;position:relative}
.wg-card:hover{box-shadow:var(--shd2);transform:translateY(-1px)}
.wg-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--wc,var(--ac))}
.wg-hd{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 16px 8px;gap:8px}
.wg-ht{font-size:12px;font-weight:700;color:var(--tx);flex:1;line-height:1.3}
.wg-ac{display:flex;gap:3px;opacity:0;transition:opacity .12s;flex-shrink:0}
.wg-card:hover .wg-ac{opacity:1}
.wg-body{padding:4px 16px 16px}
.wg-counter{text-align:center;padding:10px 0 4px}
.wg-cv{font-size:46px;font-weight:800;line-height:1;color:var(--wc,var(--ac));letter-spacing:-2px}
.wg-cl{font-size:11px;color:var(--mu);margin-top:5px;line-height:1.3}
.wg-legend{display:flex;flex-direction:column;gap:4px;margin-top:10px}
.wg-leg{display:flex;align-items:center;gap:7px;font-size:11px;cursor:default}
.wg-leg-c{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.wg-leg-l{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--tx)}
.wg-leg-v{color:var(--mu);font-size:10px;flex-shrink:0}
.wg-leg-pct{color:var(--mu);font-size:10px;flex-shrink:0;width:28px;text-align:right}
.wg-empty{text-align:center;color:var(--mu);font-size:11px;padding:20px 0;font-style:italic}
.wg-add{border:2px dashed var(--brd);border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:160px;cursor:pointer;transition:all .15s;background:transparent}
.wg-add:hover{border-color:var(--ac);background:var(--sur)}
.wg-add:hover .wg-add-ic,.wg-add:hover .wg-add-la{color:var(--ac)}
.wg-add-ic{font-size:26px;color:var(--mu)}
.wg-add-la{font-size:12px;color:var(--mu);font-weight:600}
/* Widget type picker in dialog */
.wt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.wt-item{border:2px solid var(--brd);border-radius:10px;padding:14px 8px;text-align:center;cursor:pointer;transition:border-color .1s,background .1s}
.wt-item:hover,.wt-item.wton{border-color:var(--ac);background:var(--ac2)}
.wt-ic{font-size:22px;margin-bottom:4px}
.wt-la{font-size:11px;font-weight:600;color:var(--tx)}
.wg-src-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.wg-src-item{border:1px solid var(--brd);border-radius:7px;padding:8px 10px;cursor:pointer;font-size:12px;transition:all .1s}
.wg-src-item:hover,.wg-src-item.wton{border-color:var(--ac);background:var(--ac2);color:var(--ac)}

/* ── AUTH / LOGIN SCREEN ─────────────────────────────────── */
.login-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#1a1460 0%,#2d1f8e 40%,#1a1460 100%);z-index:9999;display:none;align-items:center;justify-content:center;padding:16px}
.login-overlay.open{display:flex}
.login-card{background:var(--sur);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:40px 36px 32px;width:min(420px,100%);box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.08);text-align:center}
.login-logo{margin-bottom:16px}
.login-title{font-size:22px;font-weight:800;color:var(--tx);letter-spacing:-.5px;margin-bottom:4px}
.login-sub{font-size:13px;color:var(--mu);margin-bottom:24px}
.login-err{background:#fee2e2;color:#991b1b;border-radius:9px;padding:10px 14px;font-size:12px;margin-bottom:16px;text-align:left}
.login-ya-btn{width:100%;padding:13px 20px;border-radius:12px;border:none;background:#2c3d56;color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .15s}
.login-ya-btn:hover{background:#1e2d42}
.login-divider{display:flex;align-items:center;gap:10px;margin:16px 0;color:var(--mu);font-size:12px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--brd)}
.login-pin-btn{width:100%;padding:11px 20px;border-radius:12px;border:1px solid var(--brd);background:var(--sur2);color:var(--tx);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .1s}
.login-pin-btn:hover{background:var(--brd)}
.login-footer{font-size:11px;color:var(--mu);margin-top:20px;line-height:1.5}
.login-setup{background:var(--sur2);border:1px solid var(--brd);border-radius:10px;padding:14px 16px;font-size:12px;color:var(--tx);text-align:left;line-height:1.6}
.login-setup-link{display:inline-block;margin-top:8px;font-size:12px;color:var(--ac);text-decoration:none;font-weight:500}
.login-loading{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 20px;color:var(--mu);font-size:13px}
.login-spinner{width:32px;height:32px;border:3px solid var(--brd);border-top-color:var(--ac);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── USER BADGE (header) ─────────────────────────────────── */
.user-badge{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:20px;padding:4px 10px 4px 4px;cursor:pointer;color:#fff;font-size:12px;font-weight:500;transition:background .1s;white-space:nowrap}
.user-badge:hover{background:rgba(255,255,255,.2)}
.user-avatar-sm{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.3);color:#fff;font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}

/* ── USER MANAGEMENT (admin) ─────────────────────────────── */
.auth-user-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--brd)}
.auth-user-row:last-child{border-bottom:none}
.auth-user-self{background:var(--sur2);border-radius:10px;padding:10px 12px;margin:0 -12px}
.auth-avatar{width:38px;height:38px;border-radius:50%;background:var(--ac);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;overflow:hidden;position:relative}
.auth-avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}
.auth-avatar-fb{position:relative;z-index:1}
.auth-user-info{flex:1;min-width:0}
.auth-user-name{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
.auth-user-meta{font-size:11px;color:var(--mu);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.auth-user-role{flex-shrink:0}
.auth-self-badge{font-size:10px;background:#22c55e20;color:#15803d;border-radius:100px;padding:1px 7px;font-weight:600}
.auth-role-sel{border:1px solid var(--brd);border-radius:7px;padding:5px 8px;font-size:12px;font-family:inherit;background:var(--sur2);color:var(--tx);cursor:pointer;outline:none}
.auth-role-sel:focus{border-color:var(--ac)}
.auth-empty{text-align:center;padding:20px;font-size:12px;color:var(--mu);line-height:1.6}
body.dark .login-overlay{background:rgba(18,26,40,.92)}

/* ── MILESTONE (Контрольные точки) tab ────────────────────── */
.ms-header{margin-bottom:10px}
.ms-progress-wrap{height:6px;background:var(--sur2);border-radius:3px;overflow:hidden;margin-bottom:5px}
.ms-progress-bar{height:100%;background:linear-gradient(90deg,var(--ac),#22c55e);border-radius:3px;transition:width .3s}
.ms-meta{font-size:11px;color:var(--mu);display:flex;align-items:center;gap:8px}
.ms-add-btn{margin-left:auto}
.ms-table-wrap{overflow-x:auto}
.ms-table{width:100%;border-collapse:collapse;font-size:12px}
.ms-table th{text-align:left;font-size:10px;color:var(--mu);font-weight:600;padding:4px 6px 6px;border-bottom:2px solid var(--brd);white-space:nowrap}
.ms-table td{padding:5px 6px;border-bottom:1px solid var(--sur2);vertical-align:middle}
.ms-row{transition:background .1s;cursor:default}
.ms-row:hover{background:var(--sur2)}
.ms-row.ms-done td{opacity:.5}
.ms-row.ms-done .ms-name-text{text-decoration:line-through}
.ms-row.ms-dragging{opacity:.5;background:var(--sur2)}
.ms-row.ms-over{border-top:2px solid var(--ac)}
.ms-drag-handle{cursor:grab;color:var(--mu);font-size:14px;width:18px;text-align:center;user-select:none}
.ms-drag-handle:active{cursor:grabbing}
.ms-name-cell{display:flex;align-items:center;gap:5px;min-width:0}
.ms-check{cursor:pointer;width:14px;height:14px;accent-color:var(--ac);flex-shrink:0}
.ms-name-text{flex:1;min-width:0}
.ms-kt-mark{flex-shrink:0}
.ms-role-badge{font-size:10px;padding:1px 7px;border-radius:8px;font-weight:500;white-space:nowrap}
.ms-inp{width:100%;border:1px solid var(--brd);border-radius:5px;padding:3px 6px;font-size:11px;font-family:inherit;background:var(--sur);color:var(--tx);outline:none}
.ms-inp:focus{border-color:var(--ac)}
.ms-sel{border:1px solid var(--brd);border-radius:5px;padding:3px 5px;font-size:11px;font-family:inherit;background:var(--sur);color:var(--tx);outline:none}
.ms-edit-row td{background:var(--sur2)}
body.dark .ms-inp,.body.dark .ms-sel{background:var(--sur2);color:var(--tx)}

/* ── STAFF UTILIZATION widget ──────────────────────────────── */
.util-row{padding:8px 0;border-bottom:1px solid var(--sur2)}
.util-row:last-child{border-bottom:none}
.util-name{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:4px}
.util-bar-wrap{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.util-bar{height:12px;min-width:4px;border-radius:6px;transition:width .4s;background:var(--ac)}
.util-pct{font-size:11px;color:var(--mu);flex-shrink:0}
.util-advice{font-size:10px;font-weight:500;margin-bottom:4px}
.util-tasks{display:flex;flex-wrap:wrap;gap:4px}
.util-task-tag{font-size:10px;padding:1px 6px;border-radius:8px;white-space:nowrap;overflow:hidden;max-width:120px;text-overflow:ellipsis}
.util-sep{height:1px;background:var(--brd);margin:4px 0}

/* ── GIS CARD segmented progress bar ───────────────────────── */
.gm-prog-segs{display:flex;gap:1px;margin-top:3px}
.gm-prog-seg{flex:1;height:4px;border-radius:1px;background:rgba(0,0,0,.13);min-width:2px;transition:background .2s}
body.dark .gm-prog-seg{background:rgba(255,255,255,.15)}
.gm-prog-seg.gm-ps-on{background:#22c55e}
body.pgis .gm-prog-segs{display:none!important}

/* ── SEARCH overlay improvements ──────────────────────────── */
.srch-ov-count{font-size:10px;color:var(--mu);padding:6px 12px 2px;border-bottom:1px solid var(--sur2)}
.srch-ov-hint{font-size:10px;color:var(--mu);padding:4px 12px;text-align:center}
.srch-ovit-sel{background:var(--sur2)!important}
.srch{transition:width .2s}
.srch:focus{width:300px}

/* Feedback button */
#feedbackBtn{transition:transform .15s,background .2s}

/* User management table */
.nu-table{width:100%;border-collapse:collapse;font-size:12px}
.nu-table th,.nu-table td{padding:8px 10px}
.nu-table thead tr{border-bottom:2px solid var(--brd)}
.nu-table tbody tr{border-bottom:1px solid var(--brd)}
.nu-table tbody tr:nth-child(even){background:var(--sur2)}

/* Login modal */
.login-logo{font-size:48px;text-align:center;margin-bottom:12px}

/* Feedback message cards */
.fb-msg{display:flex;gap:12px;padding:12px;border-radius:8px;margin-bottom:8px;border:1px solid var(--brd)}
.fb-msg.unread{background:var(--ac2);border-color:var(--ac)}

/* User avatar updated */
.user-avatar-sm{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;overflow:hidden;font-weight:700;color:#fff}


/* Generated password display */
.genpass-box{display:flex;align-items:center;gap:8px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:8px 12px;margin-top:6px}
.genpass-val{flex:1;font-size:13px;letter-spacing:1.5px;color:#166534;font-weight:600;word-break:break-all}
.genpass-copy{flex-shrink:0;white-space:nowrap}
.genpass-warn{font-size:10px;color:#dc2626;margin-top:4px;line-height:1.4;padding:0 2px}
body.dark .genpass-box{background:#052e16;border-color:#166534}
body.dark .genpass-val{color:#4ade80}

/* Login overlay error */
.lo-err-box{background:#fee2e2;color:#991b1b;border-radius:8px;padding:10px 14px;font-size:12px;margin-bottom:10px;text-align:left;line-height:1.5}
body.dark .lo-err-box{background:#3b0000;color:#fca5a5}
