:root{--royal:#17458f;--royal-d:#103269;--azure:#006bb7;--azure-d:#005a99;--gold:#f7a81b;--gold-d:#e08a0e;--ink:#16243f;--muted:#64748b;--faint:#94a3b8;--bg:#eef2f8;--card:#fff;--line:#e4e9f2;--line-2:#edf1f7;--ok:#1f8a5b;--ok-bg:#e5f4ec;--warn:#c7821a;--warn-bg:#fbf1dd;--danger:#c0392b;--danger-bg:#fbeae7;--info-bg:#e7f0fb;--r:14px;--r-sm:10px;--r-lg:20px;--shadow:0 1px 2px #1028500a, 0 6px 20px #1028500f;--shadow-lg:0 10px 40px #10285029;--sidebar-w:256px}*{box-sizing:border-box}html,body{height:100%;margin:0}body{color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:Open Sans,system-ui,sans-serif}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit}img{display:block}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:#c7d2e0 padding-box content-box;border:3px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#a9b8cc padding-box content-box}.app{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);background:var(--royal);color:#fff;z-index:5;flex-direction:column;display:flex;position:relative}.sidebar-logo{align-items:center;gap:12px;padding:26px 22px 22px;display:flex}.sidebar-logo img{width:auto;height:46px}.sidebar-scope{border-radius:var(--r-sm);background:#ffffff14;border:1px solid #ffffff1a;margin:0 16px 14px;padding:12px 14px}.sidebar-scope .lbl{letter-spacing:1.5px;text-transform:uppercase;color:#fff9;font-size:11px;font-weight:700}.sidebar-scope .val{align-items:center;gap:7px;margin-top:3px;font-size:15px;font-weight:700;display:flex}.nav{flex:1;padding:6px 12px;overflow-y:auto}.nav-section{letter-spacing:1.6px;text-transform:uppercase;color:#ffffff73;padding:16px 14px 7px;font-size:10.5px;font-weight:700}.nav-item{border-radius:var(--r-sm);color:#ffffffd1;text-align:left;align-items:center;gap:13px;width:100%;margin-bottom:2px;padding:11px 14px;font-size:14.5px;font-weight:600;transition:background .15s,color .15s;display:flex;position:relative}.nav-item:hover{color:#fff;background:#ffffff17}.nav-item.active{color:#fff;background:#ffffff24}.nav-item.active:before{content:"";background:var(--gold);border-radius:0 4px 4px 0;width:4px;height:22px;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.nav-item .ico{opacity:.95;flex:0 0 20px;width:20px;height:20px}.nav-item .badge-n{background:var(--gold);color:var(--royal-d);border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;margin-left:auto;padding:0 6px;font-size:11px;font-weight:800;display:flex}.sidebar-foot{border-top:1px solid #ffffff1f;padding:14px 16px}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--line);z-index:4;background:#fff;flex:0 0 68px;align-items:center;gap:18px;height:68px;padding:0 28px;display:flex}.topbar h1{letter-spacing:-.01em;margin:0;font-size:20px;font-weight:800}.topbar .crumb{color:var(--faint);font-size:13px;font-weight:600}.search{background:var(--bg);border:1px solid var(--line);width:300px;color:var(--muted);border-radius:999px;align-items:center;gap:9px;margin-left:auto;padding:9px 16px;display:flex}.search input{width:100%;color:var(--ink);background:0 0;border:none;outline:none;font-size:14px}.icon-btn{width:40px;height:40px;color:var(--muted);border:1px solid var(--line);background:#fff;border-radius:11px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:relative}.icon-btn:hover{background:var(--bg);color:var(--ink)}.icon-btn .dot{background:var(--gold);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:9px;right:10px}.role-pill{border:1px solid var(--line);background:#fff;border-radius:999px;align-items:center;gap:10px;padding:6px 8px 6px 14px;transition:all .15s;display:flex}.role-pill:hover{border-color:var(--azure)}.role-pill .nm{font-size:13.5px;font-weight:700;line-height:1.1}.role-pill .rl{color:var(--muted);font-size:11px;font-weight:600}.avatar{background:var(--azure);color:#fff;text-transform:uppercase;border-radius:50%;flex:none;justify-content:center;align-items:center;font-weight:800;display:flex;overflow:hidden}.menu{border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-lg);z-index:50;background:#fff;min-width:230px;padding:7px;position:absolute}.menu-item{text-align:left;width:100%;color:var(--ink);border-radius:9px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:600;display:flex}.menu-item:hover{background:var(--bg)}.menu-item.sel{background:var(--info-bg);color:var(--azure-d)}.menu-item small{color:var(--muted);margin-top:1px;font-size:11.5px;font-weight:600;display:block}.content{flex:1;padding:28px;overflow-y:auto}.content-wrap{max-width:1280px;margin:0 auto}.page-head{align-items:flex-end;gap:16px;margin-bottom:22px;display:flex}.page-head .t{letter-spacing:-.02em;margin:0;font-size:26px;font-weight:800}.page-head .s{color:var(--muted);margin-top:4px;font-size:14px}.page-head .actions{gap:10px;margin-left:auto;display:flex}.btn{white-space:nowrap;border-radius:11px;align-items:center;gap:8px;padding:10px 17px;font-size:14px;font-weight:700;transition:all .15s;display:inline-flex}.btn .ico{width:17px;height:17px}.btn-primary{background:var(--azure);color:#fff}.btn-primary:hover{background:var(--azure-d)}.btn-gold{background:var(--gold);color:var(--royal-d)}.btn-gold:hover{background:var(--gold-d)}.btn-ghost{color:var(--ink);border:1px solid var(--line);background:#fff}.btn-ghost:hover{background:var(--bg)}.btn-sm{border-radius:9px;padding:7px 13px;font-size:13px}.btn:disabled{opacity:.6;cursor:not-allowed}.grid{gap:18px;display:grid}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}.card-p{padding:22px}.card-h{border-bottom:1px solid var(--line-2);align-items:center;gap:12px;padding:18px 22px;display:flex}.card-h .ct{font-size:15.5px;font-weight:800}.card-h .cl{color:var(--azure);margin-left:auto;font-size:13px;font-weight:700}.card-h .cl:hover{text-decoration:underline}.stat{flex-direction:column;gap:14px;display:flex}.stat .top{justify-content:space-between;align-items:center;display:flex}.stat .ic{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat .v{letter-spacing:-.02em;font-size:34px;font-weight:800;line-height:1}.stat .l{color:var(--muted);margin-top:6px;font-size:13.5px;font-weight:600}.stat .trend{border-radius:999px;align-items:center;gap:4px;padding:3px 9px;font-size:12.5px;font-weight:700;display:inline-flex}.trend.up{color:var(--ok);background:var(--ok-bg)}.trend.dn{color:var(--danger);background:var(--danger-bg)}.trend.flat{color:var(--muted);background:var(--bg)}.badge{border-radius:999px;align-items:center;gap:6px;padding:4px 11px;font-size:12px;font-weight:700;display:inline-flex}.badge .d{border-radius:50%;width:6px;height:6px}.b-ok{background:var(--ok-bg);color:var(--ok)}.b-warn{background:var(--warn-bg);color:var(--warn)}.b-danger{background:var(--danger-bg);color:var(--danger)}.b-info{background:var(--info-bg);color:var(--azure-d)}.b-gold{background:var(--warn-bg);color:var(--gold-d)}.b-neutral{background:var(--bg);color:var(--muted)}.tbl{border-collapse:collapse;width:100%}.tbl th{text-align:left;letter-spacing:.6px;text-transform:uppercase;color:var(--faint);border-bottom:1px solid var(--line);white-space:nowrap;padding:13px 18px;font-size:11.5px;font-weight:700}.tbl td{border-bottom:1px solid var(--line-2);vertical-align:middle;padding:13px 18px;font-size:14px}.tbl tbody tr{cursor:pointer;transition:background .12s}.tbl tbody tr:hover{background:var(--bg)}.tbl tbody tr:last-child td{border-bottom:none}.member-cell{align-items:center;gap:12px;display:flex}.member-cell .nm{font-size:14px;font-weight:700}.member-cell .sub{color:var(--muted);font-size:12.5px}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.field{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:10px;align-items:center;gap:8px;padding:9px 13px;font-size:13.5px;display:flex}.field input,.field select{color:var(--ink);background:0 0;border:none;outline:none;font-size:13.5px;font-weight:600}.field.grow{flex:1;min-width:220px}.field.grow input{width:100%}.chip{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:700;transition:all .15s}.chip:hover{border-color:var(--azure);color:var(--azure)}.chip.on{background:var(--royal);color:#fff;border-color:var(--royal)}.meter{background:var(--line);border-radius:99px;height:8px;overflow:hidden}.meter>i{background:var(--azure);border-radius:99px;height:100%;display:block}.meter.gold>i{background:var(--gold)}.meter.ok>i{background:var(--ok)}.lrow{border-bottom:1px solid var(--line-2);align-items:center;gap:14px;padding:14px 22px;transition:all .12s;display:flex}.lrow:last-child{border-bottom:none}.lrow:hover{background:var(--bg)}.lrow .ttl{font-size:14.5px;font-weight:700}.lrow .sub{color:var(--muted);margin-top:2px;font-size:12.5px}.date-chip{background:var(--info-bg);width:54px;height:58px;color:var(--azure-d);border-radius:11px;flex-direction:column;flex:none;justify-content:center;align-items:center;display:flex}.date-chip .d{font-size:21px;font-weight:800;line-height:1}.date-chip .m{text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:11px;font-weight:700}.drawer-scrim{z-index:60;opacity:0;pointer-events:none;background:#10243f57;transition:opacity .25s;position:fixed;inset:0}.drawer-scrim.open{opacity:1;pointer-events:auto}.drawer{z-index:61;width:480px;max-width:92vw;height:100%;box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%)}.drawer.open{transform:translate(0)}.drawer-head{border-bottom:1px solid var(--line);align-items:flex-start;gap:14px;padding:22px 24px;display:flex}.drawer-body{flex:1;padding:24px;overflow-y:auto}.drawer-foot{border-top:1px solid var(--line);gap:10px;padding:16px 24px;display:flex}.kv{grid-template-columns:128px 1fr;gap:10px 16px;font-size:14px;display:grid}.kv dt{color:var(--muted);font-weight:600}.kv dd{word-break:break-word;margin:0;font-weight:700}.section-label{letter-spacing:1px;text-transform:uppercase;color:var(--faint);margin:24px 0 12px;font-size:11.5px;font-weight:800}.cal{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.cal .dow{color:var(--faint);text-transform:uppercase;text-align:center;padding-bottom:4px;font-size:11.5px;font-weight:700}.cal .cell{aspect-ratio:1;border:1px solid var(--line-2);color:var(--ink);border-radius:10px;min-height:62px;padding:7px 8px;font-size:13px;font-weight:700;position:relative}.cal .cell.dim{color:var(--faint);background:#fafbfd}.cal .cell.today{border-color:var(--azure);box-shadow:inset 0 0 0 1px var(--azure)}.cal .ev{white-space:nowrap;text-overflow:ellipsis;border-radius:6px;padding:2px 6px;font-size:10.5px;font-weight:700;position:absolute;bottom:6px;left:6px;right:6px;overflow:hidden}.t0{background:#006bb7}.t1{background:#17458f}.t2{background:#1f8a5b}.t3{background:#c7821a}.t4{background:#7a3fb0}.t5{background:#0e7c86}.t6{background:#c0392b}.t7{background:#2a6fdb}.auth-wrap{background:radial-gradient(1200px 600px at 50% -10%, #1d4f9e 0%, var(--royal) 45%, var(--royal-d) 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:420px;padding:38px 34px}.auth-card .logo{justify-content:center;margin-bottom:18px;display:flex}.auth-card .logo img{height:64px}.auth-card h1{text-align:center;margin:0 0 4px;font-size:22px;font-weight:800}.auth-card .sub{text-align:center;color:var(--muted);margin-bottom:26px;font-size:14px}.input{border:1px solid var(--line);border-radius:11px;outline:none;width:100%;margin-bottom:12px;padding:12px 14px;font-size:14.5px;transition:all .15s}.input:focus{border-color:var(--azure);box-shadow:0 0 0 3px var(--info-bg)}.label{color:var(--muted);margin-bottom:6px;font-size:12.5px;font-weight:700;display:block}.btn-block{justify-content:center;width:100%;padding:13px;font-size:15px}.auth-msg{text-align:center;border-radius:10px;margin-top:14px;padding:10px;font-size:13.5px}.divider{background:var(--line-2);height:1px;margin:18px 0}.muted{color:var(--muted)}.empty-state{text-align:center;color:var(--muted);padding:64px 24px}.empty-state .ic{background:var(--info-bg);width:64px;height:64px;color:var(--azure);border-radius:18px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.modal-scrim{z-index:70;background:#10243f73;justify-content:center;align-items:flex-start;padding:48px 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:560px}.modal-head{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:20px 24px;display:flex}.modal-head .ct{flex:1;font-size:17px;font-weight:800}.modal-body{gap:14px;padding:22px 24px;display:grid}.modal-foot{border-top:1px solid var(--line);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.form-row{gap:6px;display:grid}.form-row.two{grid-template-columns:1fr 1fr;gap:14px}.form-row label{color:var(--muted);font-size:12.5px;font-weight:700}.form-row input,.form-row select,.form-row textarea{border:1px solid var(--line);border-radius:10px;outline:none;width:100%;padding:10px 12px;font-size:14px}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--azure);box-shadow:0 0 0 3px var(--info-bg)}.menu-toggle{display:none}@media (max-width:860px){.sidebar{z-index:40;height:100vh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.search{display:none}.content{padding:18px}.menu-toggle{display:flex}}
