:root{--green:#1a8f4c;--green-d:#14753d;--green-bg:#eef8f1;--red:#c0392b;--red-bg:#fcecea;--amber:#b8860b;--blue:#2563a8;--ink:#19212e;--ink-2:#56627a;--muted:#8893a4;--line:#e7ebf1;--line-2:#d6dce5;--bg:#f5f7fb;--card:#fff;--hover:#f5f9fd;--r-sm:8px;--r-md:12px;--r-lg:16px;--s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--shadow-sm:0 1px 2px #141e320a, 0 1px 3px #141e320d;--shadow-md:0 2px 6px #141e320f, 0 6px 20px #141e320f;color:var(--ink);background:var(--bg);font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0;padding:0}body{background:var(--bg)}h1,h2,h3{color:var(--ink);letter-spacing:-.011em}h1{margin:.2rem 0 .5rem;font-size:1.6rem;font-weight:700;line-height:1.2}h2{margin:.2rem 0 .6rem;font-size:1.3rem;font-weight:650;line-height:1.25}h3{margin:0 0 .5rem;font-size:1rem;font-weight:650}button{cursor:pointer;font-family:inherit}a,.link{color:var(--blue)}:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:4px}.app{max-width:1100px;margin:0 auto;padding:0 16px 60px}.topbar{border-bottom:1px solid var(--line);z-index:10;background:var(--bg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 0;display:flex;position:sticky;top:0}.brand{letter-spacing:-.01em;align-items:center;gap:10px;font-weight:600;display:flex}.logo{background:var(--green);color:#fff;border-radius:var(--r-sm);letter-spacing:.02em;box-shadow:var(--shadow-sm);padding:5px 9px;font-size:.82rem;font-weight:700}.top-right{align-items:center;gap:10px;display:flex}.role-switch{border:1px solid var(--line);border-radius:8px;display:inline-flex;overflow:hidden}.role-switch button{color:var(--muted);background:#fff;border:0;padding:7px 14px}.role-switch button.on{background:var(--green);color:#fff}.content{padding-top:18px}.muted{color:var(--muted);font-weight:400}.sub{margin:0 0 8px;font-size:.9rem}.hint{font-size:.82rem}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.center{text-align:center}.nowrap{white-space:nowrap}.link{background:0 0;border:0;margin-bottom:8px;padding:0;font-size:.9rem}.btn{border:1px solid var(--line-2);border-radius:var(--r-sm);color:var(--ink);background:#fff;padding:8px 14px;font-size:.9rem;font-weight:500;transition:background .12s,border-color .12s,box-shadow .12s}.btn:hover{border-color:var(--muted);background:#fafbfd}.btn-ghost{color:var(--ink)}.btn-primary{background:var(--green);color:#fff;border-color:var(--green);font-weight:600}.btn-primary:hover{background:var(--green-d);border-color:var(--green-d)}.btn-primary:disabled{color:#fff;cursor:not-allowed;background:#cdd5df;border-color:#cdd5df}.btn-danger{color:var(--red);border-color:var(--line-2)}.btn-danger:hover{background:var(--red-bg);border-color:var(--red)}.btn-big{width:100%;margin-top:10px;padding:13px;font-size:1rem}.badge{color:var(--muted);background:#eef1f6;border-radius:20px;padding:3px 10px;font-size:.76rem}.badge-ok{color:var(--green-d);background:#e3f4ea}.badge-warn{color:var(--amber);background:#fcf0d8}.pill{color:var(--muted);white-space:nowrap;background:#eef1f6;border-radius:20px;padding:3px 10px;font-size:.78rem}.pill-work{color:var(--blue);background:#e6f0fa}.pill-closed{color:var(--green-d);background:#e3f4ea}.theme{color:var(--muted);font-size:.82rem}.theme-ready:before{content:"🟢 "}.sla{white-space:nowrap;border-radius:10px;padding:1px 8px;font-size:.82rem;font-weight:600}.sla-over{color:var(--red);background:#fbe7e3}.sla-urgent{color:var(--amber);background:#fcf0d8}.sla-ok{color:var(--ink);background:0 0;font-weight:500}.sla-done{color:var(--muted);background:0 0;font-weight:400}.sla-date{font-size:.78rem}.grid{border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);width:100%;box-shadow:var(--shadow-sm);overflow:hidden}.grid th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--line-2);background:#fbfcfe;padding:11px 14px;font-size:.72rem;font-weight:600}.grid td{border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink);padding:12px 14px;font-size:.9rem}.grid tr:last-child td{border-bottom:0}.row{cursor:pointer;transition:background .1s}.row:hover td{background:var(--hover)}.addr{max-width:240px}.reason{max-width:320px;color:var(--ink-2);font-size:.85rem}.inbox-head h2{margin-bottom:2px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-sm);margin:14px 0;padding:18px 20px}.card-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.meta{align-items:center;gap:12px;margin:4px 0 10px;display:flex}.reason-box{border:1px solid var(--line);background:#f8fafc;border-radius:8px;padding:10px 12px;font-size:.9rem}.fields{grid-template-columns:1fr 1fr;gap:8px 24px;display:grid}.field{flex-direction:column;gap:2px;display:flex}.fk{color:var(--muted);text-transform:uppercase;font-size:.74rem}.fv{font-size:.92rem}.edit-grid{border-top:1px solid var(--line);grid-template-columns:1fr 1fr;gap:12px 24px;margin-top:12px;padding-top:12px;display:grid}.edit-field{flex-direction:column;gap:4px;display:flex}.edit-field input[type=text],.edit-field input:not([type]),.edit-field input[type=number],.edit-field select{border:1px solid var(--line);background:#fff;border-radius:8px;padding:8px;font-size:.9rem}.edit-field input[type=number].qty{width:90px}.checkbox-field{flex-direction:row;align-items:center;gap:8px}.checkbox-field input{width:auto}.edit-actions{grid-column:1/-1;align-items:center;gap:12px;display:flex}.muted.ok{color:var(--green)}.project-card .edit-grid{border-top:0;margin-top:0;padding-top:0}@media (width<=640px){.edit-grid{grid-template-columns:1fr}}.spec-line{border-bottom:1px dashed var(--line);flex-wrap:wrap;align-items:center;gap:10px;padding:8px 0;display:flex}.spec-name{flex:1;min-width:180px;font-size:.9rem}.spec-amount{text-align:right;min-width:70px;font-weight:600}.qty{border:1px solid var(--line);border-radius:6px;width:56px;padding:5px}.x{color:var(--muted);background:0 0;border:0;font-size:.9rem}.add-work{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.add-work select{border:1px solid var(--line);border-radius:8px;flex:1;padding:8px}.materials-block{border-top:1px solid var(--line);margin-top:16px;padding-top:12px}.materials-block h4{margin:0 0 4px;font-size:.95rem}.add-material-free input[type=text]{border:1px solid var(--line);border-radius:8px;flex:1;min-width:140px;padding:8px}.total{text-align:right;margin-top:10px;font-size:1rem}.markup-inp{border:1px solid var(--line);border-radius:5px;width:52px;margin-left:2px;padding:1px 4px;font-size:.85rem}.doc-buttons{flex-wrap:wrap;gap:8px;display:flex}.doc{border:1px dashed var(--line);color:var(--muted);background:#fff;border-radius:8px;padding:9px 14px;font-size:.88rem}.doc.on{border-style:solid;border-color:var(--green);color:var(--green-d);background:#e3f4ea}textarea,.card select{border:1px solid var(--line);border-radius:8px;width:100%;margin-bottom:8px;padding:9px;font-family:inherit;font-size:.9rem}.gate{border:2px solid;border-radius:12px;margin:14px 0;padding:16px}.gate-block{border-color:var(--red);background:#fdf2f1}.gate-ok{border-color:var(--green);background:#eefaf2}.checklist{margin:0 0 8px;padding:0;list-style:none}.checklist li{gap:8px;padding:5px 0;font-size:.92rem;display:flex}.checklist .mark{width:16px;font-weight:700}.checklist .ok .mark{color:var(--green)}.checklist .bad .mark{color:var(--red)}.hint-inline{color:var(--red);font-size:.85rem;font-style:normal}.banner{border-radius:8px;margin:12px 0;padding:10px 14px;font-size:.9rem}.banner-warn{color:var(--amber);background:#fcf0d8;border:1px solid #f0dca8}.portal-fields{border-collapse:collapse;width:100%;margin:6px 0 12px}.portal-fields td{border-bottom:1px solid var(--line);padding:8px 10px;font-size:.92rem}.pf-label{color:var(--muted);width:200px}.pf-val{font-weight:500}.pf-empty{color:var(--red)}.synth{margin:8px 0 14px;font-size:.88rem}.synth summary{cursor:pointer;color:var(--blue)}.history{margin:0;padding:0;font-size:.88rem;list-style:none}.history li{border-bottom:1px solid var(--line);padding:4px 0}@media (width<=640px){.fields{grid-template-columns:1fr}.reason,.addr{max-width:none}.topbar{gap:8px}}.login-wrap{justify-content:center;align-items:center;min-height:80vh;padding:24px;display:flex}.login-card{background:var(--card);border:1px solid var(--line);border-radius:14px;width:100%;max-width:360px;padding:28px 26px;box-shadow:0 6px 24px #141e320f}.brand-big{margin-bottom:2px;font-size:1.25rem}.fld{margin:14px 0;display:block}.fld span{color:var(--muted);margin-bottom:5px;font-size:.8rem;display:block}.fld input{border:1px solid var(--line);box-sizing:border-box;border-radius:8px;width:100%;padding:10px 12px;font-size:.95rem}.fld input:focus{border-color:var(--green);outline:none}.login-error{color:#b22;background:#fdecec;border-radius:8px;margin-top:6px;padding:9px 12px;font-size:.85rem}.user-chip{color:var(--ink);font-size:.85rem}.mainnav{border-bottom:1px solid var(--line);gap:2px;margin-top:4px;display:flex}.navtab{color:var(--ink-2);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 16px;font-size:.92rem;transition:color .12s}.navtab:hover{color:var(--ink)}.navtab.on{color:var(--green-d);border-bottom-color:var(--green);font-weight:600}.markup-edit{align-items:center;gap:4px;display:inline-flex}.markup-edit .qty{width:64px}.card-title{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.card-title h2{margin:0}.actionbar{background:var(--card);border:1px solid var(--line);border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;margin:12px 0;padding:12px;display:flex}.actionbar .btn-primary{padding:7px 12px;font-size:.85rem}.actionbar .assign{color:var(--muted);align-items:center;gap:6px;margin-left:auto;font-size:.85rem;display:inline-flex}.actionbar .assign select{border:1px solid var(--line);border-radius:8px;padding:6px 8px}.tabs{border-bottom:1px solid var(--line);gap:2px;margin:14px 0 0;display:flex}.tab{color:var(--muted);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 14px;font-size:.88rem}.tab.on{color:var(--green-d);border-bottom-color:var(--green);font-weight:600}.tab:hover{color:var(--ink)}.pill-pending{color:var(--amber);background:#fcf0d8}.pill-cancel{color:#999;background:#f1f1f4;text-decoration:line-through}.doclist{flex-direction:column;gap:8px;padding:0;list-style:none;display:flex}.userform{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.userform input,.userform select{border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:.9rem}.row-inactive{opacity:.5}.piece-toggle{white-space:nowrap;align-items:center;gap:6px;font-size:.85rem;display:inline-flex}.piece-toggle input[type=number]{width:56px}.board-total{border:1px solid var(--line);background:#fafbfc}.board-row-head{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.board-row-head h3{flex:220px;margin:0}.board-bar{background:#eef0f2;border-radius:7px;flex:200px;min-width:180px;height:14px;display:flex;overflow:hidden}.board-bar-empty{opacity:.5}.board-bar .seg{height:100%}.seg-closed{background:#4ca070}.seg-work{background:#4080a8}.seg-cancel{background:#cbd2d8}.board-kpis{flex-wrap:wrap;gap:10px;margin:10px 0 6px;display:flex}.kchip{background:#f1f3f5;border-radius:8px;padding:4px 10px;font-size:.85rem}.kchip b{margin-right:3px;font-size:1.05rem}.kchip-work{background:#e7f0f6}.kchip-closed{background:#e6f3ec}.kchip-overdue{color:var(--red);background:#fbe7e3}.board-outcomes{flex-wrap:wrap;gap:16px;font-size:.82rem;display:flex}.legend{vertical-align:middle;border-radius:3px;width:12px;height:12px;margin:0 4px 0 10px;display:inline-block}.metrics{flex-wrap:wrap;gap:12px;display:flex}.metric{border:1px solid var(--line);border-radius:var(--r-md);min-width:140px;box-shadow:var(--shadow-sm);background:#fff;flex:1;padding:18px}.metric-accent{background:var(--green-bg);border-color:#bfe3cc}.metric-value{color:var(--ink);font-size:1.8rem;font-weight:700}.metric-accent .metric-value{color:var(--green-d)}.metric-label{margin-top:4px;font-size:.85rem}.metric-hint{margin-top:2px;font-size:.76rem}.chips{flex-wrap:wrap;gap:8px;display:flex}.userform-col{flex-direction:column;gap:12px;max-width:420px;display:flex}.userform-col label{color:var(--muted);flex-direction:column;gap:4px;font-size:.85rem;display:flex}.profile-meta{margin:4px 0 12px;font-size:.85rem}.row-actions{white-space:nowrap;gap:6px;display:flex}.detail-row td{background:#f8fafc}.user-detail{grid-template-columns:minmax(280px,1fr) 1.4fr;align-items:start;gap:24px;display:grid}.user-detail h4{margin:0 0 10px;font-size:.9rem}.user-detail-edit{flex-direction:column;gap:10px;display:flex}.user-detail-edit label{color:var(--muted);flex-direction:column;gap:4px;font-size:.8rem;display:flex}.stats-panel{flex-direction:column;gap:12px;display:flex}.stats-grid{flex-wrap:wrap;gap:12px;display:flex}.stats-card{border:1px solid var(--line);background:#fff;border-radius:10px;flex:1;min-width:200px;padding:12px 14px}.stats-card h4{text-transform:uppercase;letter-spacing:.02em;color:var(--muted);margin:0 0 8px;font-size:.82rem}.metric-row{justify-content:space-between;gap:12px;padding:3px 0;font-size:.9rem;display:flex}.metric-val{color:var(--ink);font-weight:600}@media (width<=720px){.user-detail{grid-template-columns:1fr}}.banner-ok{color:var(--green-d);background:#e3f4ea;border:1px solid #b9e3c8}@media (width<=640px){.grid-cards{background:0 0;border:0;border-radius:0;display:block;overflow:visible}.grid-cards thead{display:none}.grid-cards tbody,.grid-cards tr,.grid-cards td{width:100%;display:block}.grid-cards tr.row{background:var(--card);border:1px solid var(--line);border-radius:12px;margin-bottom:12px;padding:12px 14px}.grid-cards tr.row:hover td{background:0 0}.grid-cards td{vertical-align:baseline;border:0;align-items:baseline;gap:12px;max-width:none;padding:4px 0;font-size:1rem;display:flex}.grid-cards td:before{content:attr(data-label);color:var(--muted);text-transform:uppercase;letter-spacing:.02em;flex:0 0 96px;font-size:.78rem;line-height:1.5}.grid-cards td.addr{font-size:1.08rem;font-weight:600;line-height:1.35}.grid-cards td.reason{color:var(--muted);font-size:.92rem}.grid-cards .sla-date{display:block}.grid-cards td[data-label=Зарегистрирована]{display:none}}.tech{max-width:560px}.tech .doc{align-items:center;min-height:44px;padding:10px 16px;font-size:.92rem;display:inline-flex}.tech .add-work select,.tech .add-work button,.tech .add-material-free input[type=text]{min-height:44px}.tech .add-work select{font-size:.95rem}.tech .qty{width:64px;min-height:40px;font-size:1rem}.tech .spec-name{font-size:.95rem}.tech .checklist li{padding:6px 0;font-size:.95rem}.tech textarea,.tech .card select{min-height:44px;font-size:1rem}.tech .x{min-width:40px;min-height:40px;font-size:1.1rem}.tech-actionbar{z-index:5;background:var(--card);border-top:1px solid var(--line);align-items:center;gap:14px;margin:16px -16px 0;padding:12px 16px;display:flex;position:sticky;bottom:0;box-shadow:0 -3px 10px #141e3212}.tech-actionbar .progress{flex:1;font-size:.92rem;line-height:1.3}.tech-actionbar .progress b{font-size:1.05rem}.tech-actionbar .progress .ok-mark{color:var(--green)}.tech-actionbar .progress .left-mark{color:var(--red)}.tech-actionbar .btn-big{white-space:nowrap;flex:none;width:auto;margin-top:0;padding:13px 22px}.mainnav{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.mainnav::-webkit-scrollbar{display:none}.navtab{white-space:nowrap;flex:none}.card.synced{border-left:3px solid var(--green)}.synced-text{color:var(--ink);background:#f3faf5;border:1px solid #cdead8;border-radius:8px;margin:4px 0 8px;padding:11px 13px;font-size:1rem;line-height:1.45}.filterbar{flex-wrap:wrap;align-items:flex-end;gap:10px 14px;margin:4px 0 12px;display:flex}.filterbar .filter{flex-direction:column;gap:3px;display:flex}.filterbar .filter .fk{color:var(--muted);font-size:.78rem}.filterbar .filter select{min-width:150px}
