:root{--azure: #1E7BFF;--azure-deep: #0F4FBF;--azure-soft: #EEF1F6;--azure-tint: #EAF2FF;--ink: #0E1626;--ink-2: #1A2230;--muted: #5A6478;--dim: #8993A3;--line: #ECEEF2;--line-soft: #F1F3F6;--bg: #FAFBFD;--surface: #FFFFFF;--green: #10A363;--green-soft: #E3F6EC;--green-tint: #ECFBF1;--red: #DC3545;--red-soft: #FBE0E0;--red-tint: #FDECEC;--orange: #E85A2B;--orange-soft: #FFE9D9;--yellow: #B07A2C;--yellow-soft: #FBEDDC;--yellow-tint: #FDF5E1;--purple: #8B47E0;--purple-soft: #F3EBFF;--slate: #3F4757;--slate-soft: #F0F2F6}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:Google Sans,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select{font:inherit}button{border:0;background:transparent;cursor:pointer}.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.side{background:var(--surface);border-right:.5px solid var(--line);padding:22px 16px 24px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:100;transition:transform .25s ease}.s-brand{display:flex;gap:12px;align-items:center;padding:4px 6px 22px}.s-mark{width:38px;height:38px;border-radius:10px;background:var(--azure-tint);color:var(--azure);display:grid;place-items:center;flex-shrink:0}.s-brand .who{display:flex;flex-direction:column;line-height:1.25;min-width:0}.s-brand .who b{font-weight:700;font-size:18px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.s-brand .who small{font-size:12.5px;color:var(--muted)}.s-grp{display:flex;flex-direction:column;gap:2px;padding:14px 0 6px;border-top:.5px solid var(--line-soft)}.s-grp-h{font-size:11.5px;font-weight:500;color:var(--dim);letter-spacing:.02em;padding:6px 10px 10px}.s-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:9px;font-size:14.5px;font-weight:500;color:#2d3748;text-align:left;transition:background .15s ease,color .15s ease}.s-item:hover{background:#f4f6fa}.s-item.active{background:var(--azure-soft);color:var(--azure)}.s-item svg{color:#5a6478;flex-shrink:0;transition:color .15s ease}.s-item.active svg{color:var(--azure)}.sidebar-spacer{flex:1}.sidebar-account{border-top:.5px solid var(--line-soft);padding-top:14px;display:flex;flex-direction:column;gap:8px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;min-width:0}.sidebar-user b,.sidebar-user small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user b{font-size:13px;color:var(--ink-2)}.sidebar-user small{font-size:12px;color:var(--muted);max-width:168px}.logout-btn{color:var(--red)}.logout-btn svg{color:var(--red)}.main{min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:16px;padding:14px 32px;background:var(--surface);border-bottom:.5px solid var(--line);min-height:64px;position:sticky;top:0;z-index:10}.crumb{font-weight:600;font-size:17px;color:var(--ink)}.hamburger{display:none;width:36px;height:36px;border-radius:8px;align-items:center;justify-content:center;color:var(--muted)}.hamburger:hover{background:var(--line-soft);color:var(--ink)}.user{margin-left:auto;display:flex;align-items:center;gap:14px}.user .meta{display:flex;flex-direction:column;align-items:flex-end;line-height:1.25}.user .meta b{font-weight:600;font-size:13.5px;color:var(--ink-2)}.user .meta small{font-size:12px;color:var(--muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.av{width:36px;height:36px;border-radius:50%;background:#d9e5f7;color:var(--azure);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.content{padding:28px 32px 64px;display:flex;flex-direction:column;gap:22px}.pageh{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}.pageh h1{font-weight:700;font-size:28px;margin:0 0 6px;color:var(--ink)}.pageh p{margin:0;color:var(--muted);font-size:14px}.pageh .actions{display:flex;gap:10px;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 18px;border-radius:10px;font-weight:600;font-size:14px;transition:transform .12s,background .15s,box-shadow .15s,border-color .15s,color .15s;white-space:nowrap}.btn-primary{background:var(--azure);color:#fff;box-shadow:0 6px 18px #1e7bff38}.btn-primary:hover{background:var(--azure-deep);transform:translateY(-1px)}.btn-outline{background:#fff;color:var(--ink-2);border:1px solid var(--line)}.btn-outline:hover{background:var(--line-soft);border-color:#dee2ea}.btn-ghost{background:var(--line-soft);color:var(--ink-2);border:1px solid var(--line)}.btn-danger{background:var(--red-soft);color:var(--red);border:1px solid var(--red-soft)}.btn-danger:hover{background:var(--red);color:#fff}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.panel{background:var(--surface);border-radius:14px;border:.5px solid var(--line);overflow:hidden}.panel-h{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 18px;border-bottom:.5px solid var(--line-soft);flex-wrap:wrap}.panel-h .left{display:flex;align-items:center;gap:12px}.panel-h .left .ic{width:36px;height:36px;border-radius:10px;background:var(--line-soft);color:var(--muted);display:flex;align-items:center;justify-content:center}.panel-h .left b{font-weight:600;font-size:14.5px;color:var(--ink)}.panel-h .right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.panel-desc{font-size:12.5px;color:var(--muted);margin-top:2px}.stats-row{display:grid;grid-template-columns:repeat(var(--n, 3),1fr);gap:14px}.stat-card{padding:18px 22px;border-radius:14px;background:var(--c-bg, var(--surface));border:1px solid color-mix(in oklab,var(--c-fg, var(--line)) 22%,var(--line));display:flex;flex-direction:column;gap:10px}.stat-card .h{display:flex;align-items:center;gap:10px;color:var(--c-fg, var(--muted));font-weight:600;font-size:14px}.stat-card .h .ic{width:26px;height:26px;border-radius:7px;background:color-mix(in oklab,var(--c-fg, var(--azure)) 18%,transparent);display:flex;align-items:center;justify-content:center}.stat-card .v{font-weight:700;font-size:28px;line-height:1.1;color:var(--c-fg, var(--ink))}.stat-card .helper{font-size:12px;color:var(--c-fg, var(--muted));opacity:.8}.stat-card.green{--c-bg: var(--green-tint);--c-fg: var(--green)}.stat-card.yellow{--c-bg: var(--yellow-tint);--c-fg: var(--yellow)}.stat-card.red{--c-bg: var(--red-tint);--c-fg: var(--red)}.stat-card.blue{--c-bg: var(--azure-tint);--c-fg: var(--azure)}.stat-card.orange{--c-bg: var(--orange-soft);--c-fg: var(--orange)}.stat-card.purple{--c-bg: var(--purple-soft);--c-fg: var(--purple)}.stat-card.slate{--c-bg: var(--slate-soft);--c-fg: var(--slate)}.search-input{display:inline-flex;align-items:center;gap:8px;padding:0 12px;height:38px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink);font-size:13.5px;min-width:280px}.search-input:focus-within{border-color:var(--azure);box-shadow:0 0 0 3px #1e7bff1f}.search-input svg{color:var(--dim);flex-shrink:0}.search-input input{flex:1;border:0;background:transparent;outline:none;color:var(--ink);min-width:0}.search-input input::placeholder{color:var(--dim)}.field-input,.field-select{height:42px;padding:0 14px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink);font-size:14px;outline:none;width:100%}.field-input:focus,.field-select:focus{border-color:var(--azure);box-shadow:0 0 0 3px #1e7bff1f}.field-select{min-width:150px;padding-right:34px}.table-wrap{overflow-x:auto}.dt{width:100%;border-collapse:collapse}.dt th,.dt td{padding:14px 18px;text-align:left;font-size:14px;color:var(--ink-2);vertical-align:middle}.dt th{font-size:11.5px;font-weight:500;color:var(--dim);letter-spacing:.08em;text-transform:uppercase;border-bottom:.5px solid var(--line);background:var(--surface)}.dt tbody tr{border-bottom:.5px solid var(--line-soft);transition:background .15s}.dt tbody tr:last-child{border-bottom:0}.dt tbody tr:hover{background:#f8fafc}.dt .avatar-cell{display:inline-flex;align-items:center;gap:12px;min-width:260px}.dt .av.blue{background:#e0ebfc;color:var(--azure)}.dt b{color:var(--ink);font-weight:600}.mono{font-family:Google Sans,monospace;font-size:12.5px}.muted{color:var(--muted)}.small{font-size:12px;margin-top:2px}.table-note{margin-top:8px}.table-empty{text-align:center;color:var(--muted);padding:32px 18px}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;white-space:nowrap}.badge.success{background:var(--green-soft);color:var(--green)}.badge.warn{background:var(--yellow-soft);color:var(--yellow)}.badge.danger{background:var(--red-soft);color:var(--red)}.badge.muted{background:var(--line-soft);color:var(--muted)}.badge.purple{background:var(--purple-soft);color:var(--purple)}.badge.blue{background:var(--azure-tint);color:var(--azure)}.badge.orange{background:var(--orange-soft);color:var(--orange)}.badge.slate{background:var(--slate-soft);color:var(--slate)}.pager{padding:14px 18px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:13px}.pager-actions{display:flex;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0e162673;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box{background:var(--surface);border-radius:16px;border:.5px solid var(--line);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-box.wide{max-width:760px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:.5px solid var(--line-soft)}.modal-head h3{font-weight:600;font-size:16px;color:var(--ink);margin:0}.modal-head button{width:32px;height:32px;border-radius:8px;color:var(--muted);display:flex;align-items:center;justify-content:center}.modal-head button:hover{background:var(--line-soft);color:var(--ink)}.modal-body{padding:22px;display:flex;flex-direction:column;gap:16px}.modal-foot{padding:14px 22px;border-top:.5px solid var(--line-soft);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detail-box{border:1px solid var(--line);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:4px;min-width:0}.detail-box span{font-size:12px;color:var(--muted);font-weight:600}.detail-box b{color:var(--ink);overflow-wrap:anywhere}.confirm-copy p{color:var(--muted);margin:8px 0 0;line-height:1.5}.alert{border-radius:10px;padding:12px 14px;font-size:13px;border:1px solid var(--line)}.alert.danger{background:var(--red-tint);color:var(--red);border-color:var(--red-soft)}.alert.success{background:var(--green-tint);color:var(--green);border-color:var(--green-soft)}.link-btn{align-self:center;color:var(--azure);font-weight:600;font-size:13px;padding:4px 8px;border-radius:8px}.link-btn:hover{background:var(--azure-tint)}.login-page,.centered-state{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.login-card,.centered-state{text-align:center}.login-card{width:min(100%,420px);background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:0 22px 80px #0e162614;display:flex;flex-direction:column;gap:14px}.login-mark{width:48px;height:48px;border-radius:12px;background:var(--azure-tint);color:var(--azure);display:grid;place-items:center;margin:0 auto}.login-card h1,.centered-state h1{margin:0;color:var(--ink);font-size:24px}.login-card p,.centered-state p{margin:0;color:var(--muted);line-height:1.5}.login-card label{display:flex;flex-direction:column;gap:6px;text-align:left;font-size:13px;font-weight:600;color:var(--ink-2)}.centered-state{flex-direction:column;gap:14px}.centered-state svg{color:var(--azure)}.sidebar-backdrop{display:none}@media(max-width:1080px){.stats-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:820px){.app{grid-template-columns:1fr}.side{position:fixed;transform:translate(-100%);width:280px;box-shadow:20px 0 40px #0e16261f}.app.sidebar-open .side{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0e16264d;z-index:90;opacity:0;pointer-events:none;transition:opacity .2s}.app.sidebar-open .sidebar-backdrop{opacity:1;pointer-events:auto}.hamburger{display:inline-flex}.topbar{padding:12px 16px}.content{padding:22px 16px 48px}.user .meta{display:none}.panel-h .right{width:100%}.search-input{width:100%;min-width:0}.field-select{width:100%}}@media(max-width:560px){.stats-row{grid-template-columns:1fr}.pageh h1{font-size:24px}.dt th,.dt td{padding:12px 14px}.detail-grid{grid-template-columns:1fr}.modal-overlay{padding:12px}.modal-foot .btn{flex:1}}
