*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:system-ui,Segoe UI,Roboto,sans-serif;line-height:1.5}:root{--bg:#f5f6f8;--surface:#fff;--surface-2:#f0f1f4;--sidebar-bg:#1a1d2e;--sidebar-text:#9ba3c0;--sidebar-active-bg:#6366f126;--sidebar-active-text:#a5b4fc;--border:#e4e5ea;--border-focus:#6366f1;--text:#374151;--text-muted:#6b7280;--text-heading:#111827;--primary:#4f46e5;--primary-h:#4338ca;--primary-text:#fff;--green:#16a34a;--green-bg:#dcfce7;--green-text:#15803d;--red:#dc2626;--red-bg:#fee2e2;--red-text:#b91c1c;--yellow:#d97706;--yellow-bg:#fef3c7;--yellow-text:#92400e;--blue:#2563eb;--blue-bg:#dbeafe;--blue-text:#1d4ed8;--gray-bg:#f3f4f6;--gray-text:#6b7280;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;--sidebar-w:220px;--topbar-h:52px;--radius-sm:4px;--radius:6px;--radius-lg:10px}#root{min-height:100vh;display:flex}.admin-shell{width:100%;min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{height:var(--topbar-h);color:#fff;letter-spacing:.02em;border-bottom:1px solid #ffffff14;flex-shrink:0;align-items:center;gap:10px;padding:0 18px;font-size:15px;font-weight:600;text-decoration:none;display:flex}.sidebar-logo svg{opacity:.85;width:22px;height:22px}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.sidebar-section-label{letter-spacing:.08em;text-transform:uppercase;color:#ffffff4d;padding:14px 8px 6px;font-size:10px;font-weight:600}.sidebar-link{border-radius:var(--radius);color:var(--sidebar-text);align-items:center;gap:9px;margin-bottom:1px;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-link svg{opacity:.7;flex-shrink:0;width:16px;height:16px}.sidebar-link:hover{color:#c4c9e0;background:#ffffff12}.sidebar-link[data-status=active],.sidebar-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text)}.sidebar-link[data-status=active] svg,.sidebar-link.active svg{opacity:1}.sidebar-footer{color:#ffffff4d;border-top:1px solid #ffffff14;padding:12px 10px;font-size:12px}.main-area{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;display:flex}.topbar{z-index:50;height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{color:var(--text-heading);flex:1;font-size:15px;font-weight:600}.topbar-user{color:var(--text-muted);align-items:center;gap:10px;font-size:13px;display:flex}.topbar-user strong{color:var(--text)}.page{flex:1;padding:24px}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-title{color:var(--text-heading);font-size:20px;font-weight:600}.page-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title{color:var(--text-heading);font-size:14px;font-weight:600}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px 20px}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:12px;font-weight:500}.stat-value{color:var(--text-heading);font-size:28px;font-weight:700;line-height:1}.stat-trend{color:var(--text-muted);margin-top:4px;font-size:12px}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;line-height:1.4;transition:background .15s,border-color .15s,box-shadow .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn svg{flex-shrink:0;width:15px;height:15px}.btn-primary{background:var(--primary);color:var(--primary-text);border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-h);border-color:var(--primary-h)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-2)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{border-radius:var(--radius-sm);padding:6px}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filter-bar .input{min-width:200px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:11px 14px}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-2)}.td-mono{font-family:ui-monospace,Consolas,monospace;font-size:12px}.td-actions{align-items:center;gap:4px;display:flex}.badge{white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;line-height:1.6;display:inline-flex}.badge-green{background:var(--green-bg);color:var(--green-text)}.badge-red{background:var(--red-bg);color:var(--red-text)}.badge-yellow{background:var(--yellow-bg);color:var(--yellow-text)}.badge-blue{background:var(--blue-bg);color:var(--blue-text)}.badge-gray{background:var(--gray-bg);color:var(--gray-text)}.badge-dot:before{content:"";opacity:.8;background:currentColor;border-radius:50%;width:6px;height:6px;display:inline-block}.form-group{margin-bottom:16px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}label{color:var(--text);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.required-mark{color:var(--red);margin-left:2px}.input,.select,.textarea{width:100%;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:8px 11px;font-family:inherit;font-size:13px;line-height:1.4;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f11f}.input::placeholder{color:var(--text-muted);opacity:.7}.select{cursor:pointer}.textarea{resize:vertical;min-height:80px}.input-hint{color:var(--text-muted);margin-top:4px;font-size:11px}.input-error{color:var(--red-text);margin-top:4px;font-size:11px}.checkbox-row{align-items:center;gap:8px;display:flex}.checkbox-row input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--primary)}.checkbox-row label{cursor:pointer;margin-bottom:0;font-weight:500}.dialog-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dialog{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;width:100%;max-width:520px;max-height:90vh;display:flex}.dialog-lg{max-width:680px}.dialog-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.dialog-title{color:var(--text-heading);font-size:16px;font-weight:600}.dialog-close{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:4px;display:flex}.dialog-close:hover{background:var(--surface-2);color:var(--text)}.dialog-body{flex:1;padding:22px;overflow-y:auto}.dialog-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}.confirm-dialog{max-width:400px}.confirm-message{color:var(--text);font-size:14px;line-height:1.6}.confirm-message strong{color:var(--text-heading)}.drawer-overlay{z-index:900;background:#00000059;position:fixed;inset:0}.drawer{background:var(--surface);z-index:901;flex-direction:column;width:480px;max-width:90vw;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 24px #0000001f}.drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.drawer-title{color:var(--text-heading);font-size:15px;font-weight:600}.drawer-body{flex:1;padding:22px;overflow-y:auto}.pagination{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;padding:14px 20px;font-size:13px;display:flex}.pagination-controls{align-items:center;gap:4px;display:flex}.alert{border-radius:var(--radius);border:1px solid #0000;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 14px;font-size:13px;display:flex}.alert svg{flex-shrink:0;width:16px;height:16px;margin-top:1px}.alert-error{background:var(--red-bg);color:var(--red-text);border-color:#fca5a5}.alert-warn{background:var(--yellow-bg);color:var(--yellow-text);border-color:#fcd34d}.alert-info{background:var(--blue-bg);color:var(--blue-text);border-color:#93c5fd}.alert-success{background:var(--green-bg);color:var(--green-text);border-color:#86efac}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.empty-state svg{opacity:.35;width:40px;height:40px;margin-bottom:12px}.empty-state p{font-size:14px}.spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:18px;height:18px;animation:.65s linear infinite spin;display:inline-block}.spinner-lg{border-width:3px;width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{justify-content:center;align-items:center;padding:64px;display:flex}.detail-grid{grid-template-columns:140px 1fr;gap:10px 16px;font-size:13px;display:grid}.detail-label{color:var(--text-muted);padding-top:1px;font-weight:500}.detail-value{color:var(--text);word-break:break-all}.collapsible-trigger{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;gap:6px;margin-bottom:8px;padding:0;font-family:inherit;font-size:13px;font-weight:600;display:flex}.collapsible-trigger:hover{color:var(--text)}.collapsible-trigger svg{width:14px;height:14px;transition:transform .15s}.collapsible-trigger.open svg{transform:rotate(90deg)}.code-block{color:#cdd6f4;border-radius:var(--radius);white-space:pre-wrap;word-break:break-all;background:#1e1e2e;padding:12px;font-family:ui-monospace,Consolas,monospace;font-size:12px;overflow-x:auto}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:380px;padding:40px}.login-logo{text-align:center;margin-bottom:28px}.login-logo-img{object-fit:contain;width:100%;max-width:180px;height:auto;margin:0 auto 12px;display:block}.login-logo p{color:var(--text-muted);font-size:13px}.password-mask{letter-spacing:2px;color:var(--text-muted);font-family:ui-monospace,Consolas,monospace}.test-result{border-radius:var(--radius-sm);align-items:center;gap:6px;padding:3px 8px;font-size:12px;display:inline-flex}.test-result.ok{background:var(--green-bg);color:var(--green-text)}.test-result.fail{background:var(--red-bg);color:var(--red-text)}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.text-muted{color:var(--text-muted)}.text-mono{font-family:ui-monospace,Consolas,monospace;font-size:12px}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mb-3{margin-bottom:12px}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}
