@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Inter:wght@300;400;500;600;700&family=Barlow+Condensed:wght@400;500;600;700;800&display=swap');
:root{--bg:#f0f2f8;--sf:#fff;--sf2:#f8f9fd;--sf3:#f0f2f8;--bd:#e2e5f0;--bd2:#c8cedf;--sb:#0f172a;--sb2:#162032;--sb3:#1e2d45;--sbt:#64748b;--sbt2:#94a3b8;--sbt3:#cbd5e1;--t1:#0f172a;--t2:#374151;--t3:#6b7280;--t4:#9ca3af;--t5:#d1d5db;--blue:#1d4ed8;--blue2:#2563eb;--blue3:#3b82f6;--blue-s:#dbeafe;--blue-ss:#eff6ff;--green:#15803d;--green2:#22c55e;--green-s:#dcfce7;--amber:#b45309;--amber2:#f59e0b;--amber-s:#fef3c7;--red:#b91c1c;--red2:#ef4444;--red-s:#fee2e2;--purple:#6d28d9;--purple2:#8b5cf6;--purple-s:#ede9fe;--teal:#0f766e;--teal2:#14b8a6;--teal-s:#ccfbf1;--orange:#c2410c;--orange2:#f97316;--orange-s:#ffedd5;--r:5px;--r2:8px;--r3:12px;--r4:16px;--sh:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.06);--sh2:0 4px 16px rgba(15,23,42,.10);--sh3:0 12px 32px rgba(15,23,42,.14);--f:'Inter',sans-serif;--fm:'DM Mono',monospace;--fh:'Barlow Condensed',sans-serif;--sb-w:232px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--t1);font-family:var(--f);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}
.app{display:flex;height:100vh;overflow:hidden}
.sidebar{width:var(--sb-w);min-width:var(--sb-w);background:var(--sb);display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.06);flex-shrink:0}
.sb-logo{padding:20px 16px 14px;border-bottom:1px solid rgba(255,255,255,.07)}
.sb-logo img{height:26px;object-fit:contain;max-width:180px;filter:brightness(0)invert(1);opacity:.92}
.sb-tag{display:flex;align-items:center;gap:6px;margin-top:8px}
.sb-dot{width:6px;height:6px;border-radius:50%;background:var(--green2);box-shadow:0 0 5px var(--green2)}
.sb-tag-t{font-size:9px;color:var(--sbt);letter-spacing:.5px;text-transform:uppercase;font-weight:600}
.nav-scroll{flex:1;overflow-y:auto;padding:8px 0}.nav-scroll::-webkit-scrollbar{display:none}
.nav-grp{font-size:9px;font-weight:700;color:rgba(255,255,255,.18);letter-spacing:1.4px;text-transform:uppercase;padding:12px 16px 5px}
.nav-item{display:flex;align-items:center;gap:9px;padding:7px 16px;cursor:pointer;color:var(--sbt2);border-left:2.5px solid transparent;transition:all .12s;font-size:12px;font-weight:500;user-select:none}
.nav-item:hover{background:var(--sb2);color:var(--sbt3)}.nav-item.active{background:rgba(37,99,235,.18);color:#fff;border-left-color:var(--blue3)}
.nav-ico{width:15px;height:15px;flex-shrink:0;opacity:.6}.nav-item.active .nav-ico{opacity:1}
.nav-badge{margin-left:auto;font-size:9px;font-weight:700;padding:1px 7px;border-radius:20px;font-family:var(--fm)}
.nb-red{background:var(--red2);color:#fff}.nb-amber{background:var(--amber2);color:#fff}.nb-blue{background:var(--blue2);color:#fff}.nb-green{background:var(--green2);color:#fff}
.sb-foot{border-top:1px solid rgba(255,255,255,.07);padding:12px 14px}
.sb-user{display:flex;align-items:center;gap:9px;cursor:pointer;padding:6px;border-radius:var(--r);transition:background .12s}
.sb-user:hover{background:var(--sb2)}
.sb-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;font-family:var(--fh)}
.sb-name{font-size:12px;font-weight:600;color:#fff}.sb-role-t{font-size:10px;color:var(--sbt)}
.sb-online{width:7px;height:7px;border-radius:50%;background:var(--green2);margin-left:auto;box-shadow:0 0 5px var(--green2)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:56px;background:var(--sf);border-bottom:1px solid var(--bd);padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-shrink:0;box-shadow:var(--sh)}
.page-title{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--t1);letter-spacing:.3px;line-height:1.2}
.page-crumb{font-size:10px;color:var(--t3);margin-top:1px}
.tb-r{display:flex;align-items:center;gap:8px;flex-shrink:0}
.tb-btn{width:34px;height:34px;border-radius:var(--r);border:1px solid var(--bd);background:var(--sf);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--t3);position:relative;transition:all .12s}
.tb-btn:hover{background:var(--sf2);color:var(--t1)}.notif-dot{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--red2);border:1.5px solid var(--sf)}
.content{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg);position:relative}
.view{display:none}.view.active{display:block}.p24{padding:24px}
.btn{padding:7px 14px;border-radius:var(--r);border:1px solid var(--bd2);background:var(--sf);font-size:12px;cursor:pointer;color:var(--t2);transition:all .12s;font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;font-family:var(--f)}
.btn:hover{background:var(--sf2);color:var(--t1)}.btn-primary{background:var(--blue2);border-color:var(--blue2);color:#fff}.btn-primary:hover{background:var(--blue)}.btn-success{background:var(--green-s);border-color:var(--green2);color:var(--green)}.btn-danger{background:var(--red-s);border-color:var(--red2);color:var(--red)}.btn-amber{background:var(--amber-s);border-color:var(--amber2);color:var(--amber)}.btn-sm{padding:5px 11px;font-size:11px}.btn-xs{padding:3px 8px;font-size:10px}.btn:disabled{opacity:.5;cursor:not-allowed}
.card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);box-shadow:var(--sh)}
.card-head{padding:14px 16px 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-title{font-size:12px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:7px;white-space:nowrap}
.card-body{padding:16px}
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;padding:24px 24px 0}
.kc{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);padding:18px 16px;position:relative;overflow:hidden;transition:box-shadow .15s,transform .15s;box-shadow:var(--sh)}
.kc:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.kc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r2)var(--r2)0 0}
.kc-blue::before{background:var(--blue2)}.kc-red::before{background:var(--red2)}.kc-green::before{background:var(--green2)}.kc-amber::before{background:var(--amber2)}.kc-purple::before{background:var(--purple2)}.kc-teal::before{background:var(--teal2)}
.kc-icon{position:absolute;top:16px;right:14px;width:34px;height:34px;border-radius:var(--r);display:flex;align-items:center;justify-content:center}
.kc-lbl{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:.7px;text-transform:uppercase;margin-bottom:10px}
.kc-val{font-size:32px;font-weight:300;line-height:1;font-family:var(--fh);letter-spacing:1px;margin-bottom:5px}
.kc-delta{font-size:10px;color:var(--t3);font-weight:500}
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;white-space:nowrap;letter-spacing:.15px}
.b-red{background:var(--red-s);color:var(--red)}.b-amber{background:var(--amber-s);color:var(--amber)}.b-green{background:var(--green-s);color:var(--green)}.b-blue{background:var(--blue-s);color:var(--blue)}.b-purple{background:var(--purple-s);color:var(--purple)}.b-teal{background:var(--teal-s);color:var(--teal)}.b-orange{background:var(--orange-s);color:var(--orange)}.b-gray{background:var(--sf3);color:var(--t2);border:1px solid var(--bd)}
.pdot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
.p1d{background:var(--red2);box-shadow:0 0 5px rgba(239,68,68,.4)}.p2d{background:var(--amber2)}.p3d{background:var(--blue2)}.p4d{background:var(--t4)}
.acct-pill{display:inline-flex;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700}
.ap-acc{background:var(--red-s);color:var(--red)}.ap-non{background:var(--green-s);color:var(--green)}.ap-shr{background:var(--amber-s);color:var(--amber)}.ap-rev{background:var(--sf3);color:var(--t2);border:1px solid var(--bd)}
.tbl-wrap{overflow-x:auto}
.tc-table{width:100%;border-collapse:collapse}
.tc-table th{text-align:left;padding:9px 12px;font-size:9px;font-weight:700;color:var(--t3);letter-spacing:.8px;text-transform:uppercase;border-bottom:1px solid var(--bd);background:var(--sf2);white-space:nowrap}
.tc-table td{padding:10px 12px;border-bottom:1px solid var(--bd);vertical-align:middle;font-size:12px;color:var(--t1)}
.tc-table tbody tr{cursor:pointer;transition:background .08s}.tc-table tbody tr:hover td{background:var(--blue-ss)}.tc-table tbody tr:last-child td{border-bottom:none}
.tc-table .rec-row td{background:rgba(220,252,231,.3)}.tc-table .rec-row:hover td{background:rgba(220,252,231,.6)!important}
.kpi-bar{display:inline-flex;align-items:center;gap:6px}
.kpi-track{width:68px;height:4px;background:var(--bd);border-radius:2px}
.kpi-fill{height:100%;border-radius:2px;transition:width .3s}.kf-ok{background:var(--green2)}.kf-warn{background:var(--amber2)}.kf-crit{background:var(--red2)}
.kpi-pct{font-size:10px;font-family:var(--fm);font-weight:500;white-space:nowrap}
.cnt-chip{font-family:var(--fm);font-size:10px;padding:2px 7px;border-radius:4px;white-space:nowrap;font-weight:500}
.cc-ok{background:var(--green-s);color:var(--green)}.cc-warn{background:var(--amber-s);color:var(--amber)}.cc-crit{background:var(--red-s);color:var(--red)}.cc-breach{background:var(--red2);color:#fff;animation:blink .8s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.filter-bar{padding:12px 24px;background:var(--sf);border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.f-chip{padding:5px 12px;border-radius:20px;border:1.5px solid var(--bd);background:var(--sf);font-size:11px;cursor:pointer;color:var(--t2);transition:all .12s;font-weight:600;font-family:var(--f)}
.f-chip:hover{border-color:var(--blue2);color:var(--blue)}.f-chip.on{background:var(--blue-s);color:var(--blue);border-color:var(--blue2)}.f-chip.rec-chip.on{background:var(--green-s);color:var(--green);border-color:var(--green2)}
.f-sel-sm{background:var(--sf);border:1.5px solid var(--bd);border-radius:var(--r);padding:5px 10px;color:var(--t2);font-size:11px;cursor:pointer;outline:none;font-weight:600;font-family:var(--f)}
.f-sel-sm:focus{border-color:var(--blue2)}
.search-inp{padding:6px 11px;border-radius:var(--r);border:1.5px solid var(--bd);background:var(--sf);color:var(--t1);font-size:11px;outline:none;width:220px;margin-left:auto;font-family:var(--f)}
.search-inp:focus{border-color:var(--blue2);box-shadow:0 0 0 3px rgba(37,99,235,.08)}
.detail-panel{position:fixed;top:0;right:-580px;width:560px;height:100vh;background:var(--sf);border-left:1px solid var(--bd);z-index:500;display:flex;flex-direction:column;transition:right .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh3)}
.detail-panel.open{right:0}
.dp-hd{padding:18px 20px;border-bottom:1px solid var(--bd);display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0;background:var(--sf2)}
.dp-meta{font-family:var(--fm);font-size:10px;color:var(--t3);margin-bottom:3px;font-weight:500}
.dp-ttl{font-size:14px;font-weight:700;color:var(--t1);line-height:1.3}
.dp-body{flex:1;overflow-y:auto;padding:18px 20px}
.dp-tabs{display:flex;border-bottom:1px solid var(--bd);flex-shrink:0;padding:0 20px;background:var(--sf)}
.dp-tab{padding:10px 14px;font-size:12px;font-weight:600;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .12s;white-space:nowrap}
.dp-tab:hover{color:var(--t1)}.dp-tab.on{color:var(--blue2);border-bottom-color:var(--blue2)}
.dp-tab-body{display:none}.dp-tab-body.on{display:block}
.x-btn{width:28px;height:28px;border-radius:var(--r);border:1px solid var(--bd);background:var(--sf);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--t3);font-size:16px;transition:all .12s;flex-shrink:0}
.x-btn:hover{background:var(--sf2);color:var(--t1)}
.dp-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.df{background:var(--sf2);border:1px solid var(--bd);border-radius:var(--r);padding:10px 12px}
.df.full{grid-column:1/-1}
.df-lbl{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:.6px;text-transform:uppercase;margin-bottom:3px}
.df-val{font-size:12px;font-weight:600;color:var(--t1)}
.sec-lbl{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:1px;text-transform:uppercase;margin:14px 0 8px;display:flex;align-items:center;gap:8px}
.sec-lbl::after{content:'';flex:1;height:1px;background:var(--bd)}
.wf-steps{display:flex;align-items:center;margin-bottom:16px;background:var(--sf2);border:1px solid var(--bd);border-radius:var(--r);padding:12px}
.wf-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;position:relative}
.wf-step:not(:last-child)::after{content:'';position:absolute;top:11px;left:calc(50% + 12px);right:calc(-50% + 12px);height:1px;background:var(--bd2)}
.wf-step.done::after{background:var(--green2)}.wf-step.cur::after{background:linear-gradient(90deg,var(--blue2),var(--bd))}
.wf-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;border:1.5px solid var(--bd2);background:var(--sf);z-index:1}
.wf-step.done .wf-dot{background:var(--green-s);border-color:var(--green2);color:var(--green)}.wf-step.cur .wf-dot{background:var(--blue-s);border-color:var(--blue2);color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.wf-step.future .wf-dot{color:var(--t4)}
.wf-lbl{font-size:8px;color:var(--t3);text-align:center;max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.wf-step.done .wf-lbl{color:var(--green)}.wf-step.cur .wf-lbl{color:var(--blue)}
.note-box{background:var(--sf2);border:1px solid var(--bd);border-radius:var(--r);padding:10px 12px}
.note-ta{width:100%;background:transparent;border:none;color:var(--t1);font-family:var(--f);font-size:12px;resize:none;outline:none;min-height:60px;line-height:1.5}
.note-ta::placeholder{color:var(--t5)}
.note-foot{display:flex;gap:8px;align-items:center;margin-top:8px;padding-top:8px;border-top:1px solid var(--bd);flex-wrap:wrap}
.fsel{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:4px 8px;color:var(--t1);font-family:var(--f);font-size:11px;cursor:pointer;outline:none}
.tl-item{display:flex;gap:10px;position:relative;padding-bottom:14px}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:9px;top:22px;width:1px;bottom:0;background:var(--bd)}
.tl-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--bd2);background:var(--sf2)}
.tl-act{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:1px}.tl-met{font-size:10px;color:var(--t3)}
.fg{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.fg3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.fld{display:flex;flex-direction:column;gap:4px}.fld.full{grid-column:1/-1}
.f-label{font-size:10px;font-weight:700;color:var(--t2);letter-spacing:.3px}.f-req{color:var(--red2)}
.f-in{background:var(--sf2);border:1.5px solid var(--bd);border-radius:var(--r);padding:7px 10px;color:var(--t1);font-size:12px;outline:none;width:100%;font-family:var(--f);transition:border-color .15s}
.f-in:focus{border-color:var(--blue2);background:var(--sf);box-shadow:0 0 0 3px rgba(37,99,235,.08)}.f-in.err{border-color:var(--red2)}
.f-sel{background:var(--sf2);border:1.5px solid var(--bd);border-radius:var(--r);padding:7px 10px;color:var(--t1);font-size:12px;outline:none;width:100%;cursor:pointer;font-family:var(--f);transition:border-color .15s}
.f-sel:focus{border-color:var(--blue2)}
.f-ta{background:var(--sf2);border:1.5px solid var(--bd);border-radius:var(--r);padding:8px 10px;color:var(--t1);font-size:12px;outline:none;resize:vertical;min-height:80px;width:100%;font-family:var(--f);line-height:1.5}
.f-ta:focus{border-color:var(--blue2);background:var(--sf)}.f-hint{font-size:10px;color:var(--t3)}
.form-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);margin-bottom:14px;box-shadow:var(--sh);overflow:hidden}
.form-card-hd{padding:12px 16px;border-bottom:1px solid var(--bd);background:var(--sf2);display:flex;align-items:center;gap:8px}
.form-card-ttl{font-size:12px;font-weight:700;color:var(--t1)}.f-body{padding:16px;display:flex;flex-direction:column;gap:12px}
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.cat-tile{border:1.5px solid var(--bd);border-radius:var(--r);padding:10px 12px;cursor:pointer;transition:all .12s;background:var(--sf2)}
.cat-tile:hover{border-color:var(--blue2);background:var(--blue-ss)}.cat-tile.sel{border-color:var(--blue2);background:var(--blue-s)}
.cat-name{font-size:12px;font-weight:700;color:var(--t1)}.cat-tile.sel .cat-name{color:var(--blue)}.cat-subs{font-size:10px;color:var(--t3);margin-top:2px}
.pri-chip,.ac-chip{padding:5px 13px;border-radius:20px;border:1.5px solid var(--bd);background:var(--sf);font-size:11px;cursor:pointer;color:var(--t2);transition:all .12s;font-weight:700;font-family:var(--f)}
.pc-P1.on{background:var(--red-s);color:var(--red);border-color:var(--red2)}.pc-P2.on{background:var(--amber-s);color:var(--amber);border-color:var(--amber2)}.pc-P3.on{background:var(--blue-s);color:var(--blue);border-color:var(--blue2)}.pc-P4.on{background:var(--sf3);color:var(--t2);border-color:var(--bd2)}
.ac-acc.on{background:var(--red-s);color:var(--red);border-color:var(--red2)}.ac-non.on{background:var(--green-s);color:var(--green);border-color:var(--green2)}.ac-shr.on{background:var(--amber-s);color:var(--amber);border-color:var(--amber2)}.ac-rev.on{background:var(--sf3);color:var(--t2);border-color:var(--bd2)}
.step-bar{display:flex;align-items:center;margin-bottom:12px}
.step-n{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--bd2);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;background:var(--sf);color:var(--t3);transition:all .2s;flex-shrink:0}
.step-n.done{background:var(--green-s);border-color:var(--green2);color:var(--green)}.step-n.cur{background:var(--blue-s);border-color:var(--blue2);color:var(--blue)}
.step-lbl{font-size:11px;color:var(--t3);margin-left:5px;font-weight:600}.step-lbl.cur{color:var(--t1)}.step-lbl.done{color:var(--green)}
.step-line{flex:1;height:1px;background:var(--bd);margin:0 6px}.step-line.done{background:var(--green2)}
.prog-wrap{height:3px;background:var(--bd);margin-bottom:18px}.prog-fill{height:100%;background:var(--blue2);transition:width .3s;border-radius:2px}
.form-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-top:1px solid var(--bd);background:var(--sf2)}
.success-wrap{text-align:center;padding:48px 24px}
.success-ring{width:68px;height:68px;border-radius:50%;border:2.5px solid var(--green2);background:var(--green-s);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;animation:popIn .4s ease}
@keyframes popIn{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.success-id{font-family:var(--fh);font-size:26px;font-weight:700;color:var(--green);letter-spacing:2px;margin-bottom:6px}
.maint-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:24px}
.maint-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);box-shadow:var(--sh)}
.maint-hd{padding:13px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--sf2);border-radius:var(--r2)var(--r2)0 0}
.maint-ttl{font-size:12px;font-weight:700;color:var(--t1)}
.maint-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--bd);transition:background .1s}
.maint-item:hover{background:var(--sf2)}.maint-item:last-child{border-bottom:none}
.mi-name{font-size:12px;font-weight:600;color:var(--t1)}.mi-sub{font-size:10px;color:var(--t3)}.mi-acts{display:flex;gap:6px;flex-shrink:0;align-items:center}
.settings-layout{display:grid;grid-template-columns:200px 1fr;gap:16px;padding:24px}
.settings-nav{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);padding:8px;box-shadow:var(--sh);align-self:start}
.sn-item{padding:8px 12px;border-radius:var(--r);font-size:12px;cursor:pointer;color:var(--t2);transition:all .12s;font-weight:600}
.sn-item:hover{background:var(--sf2);color:var(--t1)}.sn-item.on{background:var(--blue-s);color:var(--blue)}
.s-pane{display:none}.s-pane.on{display:block}
.settings-sec{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);margin-bottom:14px;box-shadow:var(--sh);overflow:hidden}
.ss-hd{padding:12px 16px;border-bottom:1px solid var(--bd);background:var(--sf2);display:flex;align-items:center;justify-content:space-between}
.ss-ttl{font-size:12px;font-weight:700;color:var(--t1)}
.toggle-wrap{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--bd)}
.toggle-wrap:last-child{border-bottom:none}.tgl-name{font-size:12px;font-weight:600;color:var(--t1)}.tgl-sub{font-size:10px;color:var(--t3)}
.toggle{position:relative;width:36px;height:20px;flex-shrink:0;cursor:pointer}.toggle input{opacity:0;width:0;height:0}
.tgl-track{position:absolute;inset:0;background:var(--bd);border-radius:20px;border:1px solid var(--bd2);transition:background .2s}
.toggle input:checked+.tgl-track{background:var(--blue2)}
.tgl-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle input:checked~.tgl-thumb{transform:translateX(16px)}
.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.4);z-index:800;display:none;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
.modal-bg.show{display:flex}
.modal{background:var(--sf);border-radius:var(--r3);padding:28px;width:540px;max-width:95vw;box-shadow:var(--sh3);border:1px solid var(--bd);animation:fadeUp .25s ease}
.modal-wide{width:780px}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-ttl{font-family:var(--fh);font-size:19px;font-weight:700;color:var(--t1);margin-bottom:3px}
.modal-sub{font-size:11px;color:var(--t3);margin-bottom:20px}
.modal-foot{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--bd)}
.notif-panel{position:fixed;top:56px;right:-370px;width:360px;height:calc(100vh - 56px);background:var(--sf);border-left:1px solid var(--bd);z-index:400;display:flex;flex-direction:column;transition:right .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh3)}
.notif-panel.open{right:0}
.np-hd{padding:14px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--sf2)}
.np-ttl{font-size:13px;font-weight:700;color:var(--t1)}.np-body{flex:1;overflow-y:auto}
.ni-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.ni-item:hover{background:var(--sf2)}.ni-item.unread{background:var(--blue-ss)}
.ni-ico{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ni-ttl{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:2px}.ni-sub{font-size:10px;color:var(--t3);line-height:1.4}.ni-time{font-size:10px;color:var(--t3);font-family:var(--fm);margin-top:2px}
.overlay{position:fixed;inset:0;background:rgba(15,23,42,.25);z-index:399;display:none;backdrop-filter:blur(2px)}.overlay.on{display:block}
.toast{position:fixed;bottom:20px;right:20px;background:var(--sf);border:1px solid var(--bd2);border-radius:var(--r2);padding:12px 16px;z-index:9999;transform:translateY(80px);opacity:0;transition:all .3s;max-width:340px;box-shadow:var(--sh2)}
.toast.on{transform:translateY(0);opacity:1}
.toast.success{border-left:3px solid var(--green2)}.toast.error{border-left:3px solid var(--red2)}.toast.info{border-left:3px solid var(--blue2)}.toast.warning{border-left:3px solid var(--amber2)}
.toast-ttl{font-size:12px;font-weight:700;color:var(--t1);margin-bottom:2px}.toast-sub{font-size:11px;color:var(--t2)}
.clock-chip{font-family:var(--fm);font-size:10px;color:var(--t3);background:var(--sf2);border:1px solid var(--bd);padding:3px 9px;border-radius:4px;letter-spacing:.3px;font-weight:500}
.mono{font-family:var(--fm)}.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.rbac-hide{display:none!important}
.loading{display:inline-flex;gap:4px;align-items:center}
.loading span{width:4px;height:4px;border-radius:50%;background:var(--t3);animation:ld .8s ease infinite}
.loading span:nth-child(2){animation-delay:.15s}.loading span:nth-child(3){animation-delay:.3s}
@keyframes ld{0%,80%,100%{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}
.inv-section{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);margin-bottom:14px;box-shadow:var(--sh);overflow:hidden}
.inv-sec-hd{padding:12px 16px;border-bottom:1px solid var(--bd);background:linear-gradient(to right,var(--sf2),var(--sf));display:flex;align-items:center;gap:8px}
.inv-sec-num{width:22px;height:22px;border-radius:50%;background:var(--blue-s);border:1.5px solid var(--blue2);color:var(--blue);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.inv-sec-ttl{font-size:12px;font-weight:700;color:var(--t1)}
.inv-status-bar{display:flex;align-items:center;gap:0;padding:12px 20px;background:var(--sf2);border-bottom:1px solid var(--bd)}
.ist-step{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--t3)}
.ist-step.done{color:var(--green)}.ist-step.cur{color:var(--blue2)}
.ist-dot{width:8px;height:8px;border-radius:50%;background:var(--bd2);flex-shrink:0}
.ist-step.done .ist-dot{background:var(--green2)}.ist-step.cur .ist-dot{background:var(--blue2);box-shadow:0 0 0 3px rgba(37,99,235,.15)}
.ist-line{flex:1;height:1px;background:var(--bd2);margin:0 8px}.ist-line.done{background:var(--green2)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.team-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);padding:18px;box-shadow:var(--sh);transition:all .15s}
.team-card:hover{border-color:var(--bd2);box-shadow:var(--sh2)}
.t-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;font-family:var(--fh)}
.t-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}
.ts-box{background:var(--sf2);border:1px solid var(--bd);border-radius:var(--r);padding:9px;text-align:center}
.ts-val{font-size:20px;font-weight:300;font-family:var(--fh)}.ts-lbl{font-size:9px;font-weight:700;color:var(--t3);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.wl-bar{height:4px;background:var(--bd);border-radius:2px;margin-top:12px;overflow:hidden}.wl-fill{height:100%;border-radius:2px}
.fin-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:24px 24px 0}
.fin-tile{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);padding:16px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh)}
.fin-ico{width:38px;height:38px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fin-lbl{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:3px}
.fin-val{font-size:22px;font-weight:300;font-family:var(--fh);letter-spacing:.3px}.fin-sub{font-size:10px;color:var(--t3);font-weight:500;margin-top:2px}
.kpi-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:24px 24px 0}
.kk-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);padding:16px;box-shadow:var(--sh)}
.kk-lbl{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:.7px;text-transform:uppercase;margin-bottom:6px}
.kk-val{font-size:30px;font-weight:300;font-family:var(--fh);line-height:1;margin-bottom:3px}.kk-sub{font-size:10px;color:var(--t3);font-weight:500}
.report-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:24px}
.r-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r2);padding:18px;cursor:pointer;transition:all .15s;box-shadow:var(--sh)}
.r-card:hover{border-color:var(--blue2);transform:translateY(-2px);box-shadow:var(--sh2)}
.r-card-ico{width:38px;height:38px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.r-card-ttl{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:4px}.r-card-sub{font-size:11px;color:var(--t2);line-height:1.5}
.r-card-foot{font-size:10px;color:var(--t3);margin-top:12px;padding-top:12px;border-top:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center}
@media print{.sidebar,.topbar,.notif-panel,.detail-panel,.overlay,.toast,.no-print{display:none!important}.content{overflow:visible!important;height:auto!important}.view{display:block!important}body{background:#fff!important;font-size:11px}.card{box-shadow:none!important;border:1px solid #ddd!important}}
