:root{--bg:#fbfcfb;--surface:#fff;--surface-2:#f3f8f5;--ink:#0e1311;--ink-2:#33403a;--grey:#68756b;--grey-2:#9aa7a0;--line:#eef1ef;--line-2:#e1e7e3;--dark:#0f1513;--green:#136a3e;--green-2:#1c874e;--green-3:#2fa164;--green-l:#e9f3ec;--green-l2:#f3f8f5;--amber:#8a6312;--amber-l:#fbf3e1;--red:#a23b34;--red-l:#fbebea;--blue:#2c5a7a;--blue-l:#e9f1f6;--glow:rgba(28,135,78,.14);--r:20px;--r-s:12px;--r-xs:10px;--sh-1:0 1px 2px rgba(16,24,20,.035);--sh-2:0 6px 22px rgba(16,24,20,.05),0 1px 3px rgba(16,24,20,.025);--sh-d:0 30px 80px rgba(16,24,20,.16);--ease:cubic-bezier(.22,.61,.36,1);--f:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--f);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55;font-size:14px;letter-spacing:-.008em}a{text-decoration:none}a,button{color:inherit}button{cursor:pointer;border:none;background:none}button,input,select,textarea{font-family:inherit}svg{stroke-linecap:round;stroke-linejoin:round}.mono{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.muted{color:var(--grey)}:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:6px}.wm{font-weight:400;color:#0e3d1e;white-space:nowrap;line-height:1}.wm .b{font-weight:800}.layout{display:grid;grid-template-columns:256px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--line);padding:20px 14px;display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh}.side-brand{padding:8px 10px 18px}.nav{display:flex;flex-direction:column;gap:1px}.nav-label{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--grey-2);padding:16px 12px 6px;font-weight:600}.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--r-s);color:var(--ink-2);font-size:13.5px;font-weight:500}.nav a svg{width:18px;height:18px;color:var(--grey)}.nav a:hover{background:var(--surface-2)}.nav a.active{background:var(--green-l)}.nav a.active,.nav a.active svg{color:var(--green)}.nav a .badge{margin-left:auto;background:var(--green);color:#fff;font-size:10.5px;font-weight:600;border-radius:20px;padding:1px 7px}.side-foot{margin-top:auto;border-top:1px solid var(--line);padding-top:12px}.userchip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-s)}.avatar{width:36px;height:36px;border-radius:11px;background:var(--dark);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}.logout{display:flex;gap:9px;align-items:center;width:100%;padding:9px 10px;color:var(--grey);font-size:13px;border-radius:var(--r-s)}.logout svg{width:16px;height:16px}.logout:hover{background:var(--surface-2)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 34px;background:rgba(251,252,251,.72);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:-webkit-sticky;position:sticky;top:0;z-index:8}.topbar h2{font-size:22px;font-weight:600;letter-spacing:-.028em}.topbar .sub{font-size:13px;color:var(--grey);margin-top:2px}.rolebar{display:flex;align-items:center;gap:10px;background:var(--dark);color:#fff;font-size:12.5px;padding:9px 34px}.rolebar svg{width:15px;height:15px;stroke:#5fd79b}.content{padding:12px 34px 90px;max-width:1240px}.grid{display:grid;grid-gap:18px;gap:18px}.g-2{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(4,1fr)}.col-2{grid-template-columns:1.55fr 1fr;align-items:start}.card{background:hsla(0,0%,100%,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(16,24,20,.045);border-radius:var(--r);box-shadow:var(--sh-2)}.card.pad{padding:22px}.ch{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:17px 22px;border-bottom:1px solid var(--line)}.ch h3{font-size:14.5px}.ch a,.ch h3{font-weight:600}.ch a{font-size:12.5px;color:var(--green);cursor:pointer;display:inline-flex;align-items:center;gap:5px}.ch a svg{width:13px;height:13px}.tile{padding:20px 22px;display:flex;flex-direction:column;gap:9px}.tile .ic{width:37px;height:37px;border-radius:12px;display:grid;place-items:center;background:var(--green-l2);border:1px solid var(--green-l);color:var(--green)}.tile .ic svg{width:17px;height:17px}.tile .lab{font-size:12.5px;color:var(--grey)}.tile .val{font-size:27px;font-weight:600;letter-spacing:-.028em}.tile .meta{font-size:12px;color:var(--grey);display:inline-flex;gap:5px}.hero,.tile .meta{align-items:center}.hero{background:linear-gradient(140deg,#12181a,#1c2a24 62%,#153a29);color:#fff;border-radius:var(--r);padding:24px;display:flex;gap:22px;box-shadow:var(--sh-2);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(95,215,155,.16),transparent 70%);top:-80px;right:-40px}.hero .when{text-align:center;background:hsla(0,0%,100%,.09);border:1px solid hsla(0,0%,100%,.13);border-radius:14px;padding:14px 20px;position:relative}.hero .when .d{font-size:32px;font-weight:700;line-height:1}.hero .when .m{letter-spacing:.12em;opacity:.85;margin-top:4px}.hero .tag,.hero .when .m{font-size:11px;text-transform:uppercase}.hero .tag{display:inline-flex;align-items:center;gap:6px;letter-spacing:.08em;background:rgba(95,215,155,.16);color:#8fe9bb;padding:4px 10px;border-radius:20px;margin-bottom:10px}.hero h4{font-size:20px;font-weight:600;margin-bottom:10px}.hero .row{display:flex;gap:20px;flex-wrap:wrap;font-size:13px;color:hsla(0,0%,100%,.82)}.hero .row span{display:flex;align-items:center;gap:7px}.hero .row svg{width:15px;height:15px}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--grey-2);font-weight:600}tbody td,thead th{padding:13px 22px;border-bottom:1px solid var(--line)}tbody td{font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-2)}.ttl{font-weight:600}.s2{font-size:12px;color:var(--grey)}.badge-s{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px}.dot{width:6px;height:6px;border-radius:50%}.b-green{background:var(--green-l);color:var(--green)}.b-green .dot{background:var(--green)}.b-amber{background:var(--amber-l);color:var(--amber)}.b-amber .dot{background:var(--amber)}.b-red{background:var(--red-l);color:var(--red)}.b-red .dot{background:var(--red)}.b-grey{background:#eff1f0;color:var(--grey)}.b-grey .dot{background:var(--grey-2)}.b-blue{background:var(--blue-l);color:var(--blue)}.b-blue .dot{background:var(--blue)}.lnk{padding:8px 12px;border:1px solid var(--line-2);border-radius:var(--r-s);font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:6px;background:var(--surface);transition:.16s var(--ease)}.lnk:hover{border-color:var(--green);color:var(--green)}.lnk svg{width:14px;height:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 18px;height:42px;border-radius:var(--r-s);font-size:13.5px;font-weight:600;transition:.18s var(--ease)}.btn svg{width:16px;height:16px}.btn-primary{background:var(--dark);color:#fff}.btn-primary:hover{transform:translateY(-1px)}.btn-green{background:linear-gradient(180deg,var(--green-2),var(--green));color:#fff;box-shadow:0 5px 14px var(--glow)}.btn-green:hover{transform:translateY(-1px);box-shadow:0 9px 20px var(--glow)}.btn-ghost{background:var(--surface);border:1px solid var(--line-2)}.btn-ghost:hover{border-color:var(--grey-2)}.field{margin-bottom:18px}label{display:block;font-size:13px;font-weight:500;color:var(--ink-2);margin-bottom:7px}input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:var(--r-s);font-size:14px;background:var(--surface)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green-2);box-shadow:0 0 0 3px var(--glow)}.pill-tabs{display:inline-flex;background:var(--green-l2);border:1px solid var(--line);border-radius:var(--r-s);padding:3px;gap:2px;margin-bottom:18px}.pill-tabs button{padding:7px 15px;border-radius:9px;font-size:13px;font-weight:600;color:var(--grey);transition:.15s}.pill-tabs button.active{background:#fff;color:var(--green);box-shadow:var(--sh-1)}.switch{position:relative;width:40px;height:23px;border-radius:20px;background:var(--green);cursor:pointer;flex:none;transition:.18s}.switch.off{background:var(--line-2)}.switch:after{content:"";position:absolute;top:2.5px;left:2.5px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.16s var(--ease)}.switch:not(.off):after{transform:translateX(17px)}.empty,.loading{padding:48px;text-align:center;color:var(--grey);font-size:13.5px}.spinner{width:22px;height:22px;border:2px solid var(--line-2);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(1turn)}}.errbox{padding:16px 18px;border:1px solid #f3d6d3;background:var(--red-l);color:var(--red);border-radius:var(--r-s);font-size:13px}.bar{height:9px;background:var(--green-l2);overflow:hidden}.bar,.bar>span{border-radius:8px}.bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--green-3),var(--green))}.skel{background:linear-gradient(100deg,#edf0ee 30%,#f6f8f7 50%,#edf0ee 70%);background-size:200% 100%;animation:skel 1.3s linear infinite;border-radius:9px}@keyframes skel{to{background-position:-200% 0}}@media(max-width:1080px){.col-2,.g-4{grid-template-columns:1fr}.g-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:920px){.layout{grid-template-columns:1fr}.sidebar{display:none}.g-3,.g-4{grid-template-columns:1fr}.content,.rolebar,.topbar{padding-left:18px;padding-right:18px}}