:root{--font-body: "Plus Jakarta Sans", sans-serif;--font-mono: "IBM Plex Mono", monospace;--brand: #16A34A;--brand-light: #DCFCE7;--brand-mid: #22C55E;--brand-dark: #15803D;--bg: #F1F5F9;--surface: #FFFFFF;--surface-2: #F8FAFC;--surface-3: #F1F5F9;--border: #E2E8F0;--border-2: #CBD5E1;--text: #0F172A;--text-2: #475569;--text-3: #94A3B8;--text-inv: #FFFFFF;--green: #16A34A;--green-bg: #F0FDF4;--green-border: #BBF7D0;--red: #DC2626;--red-bg: #FEF2F2;--red-border: #FECACA;--amber: #D97706;--amber-bg: #FFFBEB;--amber-border: #FDE68A;--blue: #2563EB;--blue-bg: #EFF6FF;--blue-border: #BFDBFE;--slate: #64748B;--slate-bg: #F8FAFC;--slate-border: #E2E8F0;--shadow-xs: 0 1px 2px rgba(15,23,42,.04);--shadow-sm: 0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 6px -1px rgba(15,23,42,.07), 0 2px 4px -2px rgba(15,23,42,.05);--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--sidebar-w: 232px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);font-size:14px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.app-shell{display:flex;height:100%;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.page-body{flex:1;overflow-y:auto;padding:28px 32px 40px}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-logo{padding:20px 16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.logo-icon{width:34px;height:34px;background:var(--brand);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 4px #16a34a4d}.logo-text-wrap{flex:1}.logo-name{font-size:15px;font-weight:800;color:var(--text);letter-spacing:.02em;line-height:1.1}.logo-sub{font-size:10.5px;color:var(--text-3);font-weight:500;margin-top:1px}.sidebar-nav{padding:10px 8px;flex:1}.nav-group-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);padding:10px 8px 5px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r-md);color:var(--text-2);text-decoration:none;font-size:13.5px;font-weight:500;cursor:pointer;border:none;background:none;width:100%;transition:color .13s,background .13s;line-height:1}.nav-item:hover{color:var(--text);background:var(--surface-3)}.nav-item.active{color:var(--brand);background:var(--brand-light);font-weight:600}.nav-item svg{flex-shrink:0}.sidebar-footer{padding:10px 8px 14px;border-top:1px solid var(--border)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:16px}.topbar-title{font-size:14px;font-weight:600;color:var(--text)}.topbar-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-3)}.topbar-right{display:flex;align-items:center;gap:8px}.page-header{margin-bottom:24px}.page-header h1{font-size:21px;font-weight:700;color:var(--text);letter-spacing:-.01em}.page-header p{font-size:13.5px;color:var(--text-2);margin-top:3px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs)}.card-p{padding:20px 22px}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-title{font-size:13px;font-weight:600;color:var(--text)}.card-subtitle{font-size:12px;color:var(--text-3);margin-top:2px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px 16px;box-shadow:var(--shadow-xs);transition:box-shadow .15s,transform .15s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{font-size:12px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px}.stat-value{font-size:32px;font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1}.stat-sub{font-size:12px;color:var(--text-3);margin-top:8px;display:flex;align-items:center;gap:4px}.stat-accent{color:var(--brand);font-weight:700;font-family:var(--font-mono);font-size:12px}.stat-icon{width:36px;height:36px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:var(--r-md);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .14s;height:34px;white-space:nowrap;line-height:1}.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 1px 3px #16a34a4d}.btn-primary:hover{background:var(--brand-dark);border-color:var(--brand-dark)}.btn-outline{background:var(--surface);color:var(--text-2);border-color:var(--border-2)}.btn-outline:hover{color:var(--text);background:var(--surface-3);border-color:var(--border-2)}.btn-ghost{background:transparent;color:var(--text-2);border-color:transparent}.btn-ghost:hover{color:var(--text);background:var(--surface-3)}.btn-danger{background:transparent;color:var(--red);border-color:var(--border)}.btn-danger:hover{background:var(--red-bg);border-color:var(--red-border)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:disabled:hover{transform:none}input,select{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-md);color:var(--text);font-family:var(--font-body);font-size:13px;padding:7px 11px;outline:none;transition:border-color .14s,box-shadow .14s;height:34px}input:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #16a34a1f}input::placeholder{color:var(--text-3)}select{cursor:pointer;padding-right:28px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap;border:1px solid transparent}.badge-green{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.badge-red{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.badge-blue{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.badge-amber{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.badge-slate{background:var(--slate-bg);color:var(--slate);border-color:var(--slate-border)}.filters-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:16px;box-shadow:var(--shadow-xs)}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-label{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs)}table{width:100%;border-collapse:collapse}thead{background:var(--surface-2)}th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .1s}tbody tr:hover{background:var(--surface-2)}.mono{font-family:var(--font-mono);font-size:12px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-top:1px solid var(--border)}.pagination-info{font-size:12.5px;color:var(--text-3)}.pagination-controls{display:flex;align-items:center;gap:6px}.loader-wrap{display:flex;align-items:center;justify-content:center;padding:64px 20px;color:var(--text-3);gap:10px;font-size:13px}.spinner{width:18px;height:18px;border:2px solid var(--border-2);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;padding:64px 20px;gap:10px;text-align:center}.empty-state svg{opacity:.25}.empty-state p{font-size:13.5px;color:var(--text-3);max-width:280px}.error-banner{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red);padding:10px 14px;border-radius:var(--r-md);font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.chart-wrap{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.segment{display:inline-flex;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--r-md);padding:3px;gap:2px}.segment-btn{padding:5px 13px;border-radius:6px;border:none;background:none;color:var(--text-2);font-family:var(--font-body);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .13s}.segment-btn.active{background:var(--surface);color:var(--brand);font-weight:600;box-shadow:var(--shadow-xs)}.legend{display:flex;flex-direction:column;gap:9px}.legend-item{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;gap:20px}.legend-label{display:flex;align-items:center;gap:8px;color:var(--text-2)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-value{font-family:var(--font-mono);font-size:12px;color:var(--text);font-weight:500}.mini-bar-wrap{display:flex;align-items:center;gap:8px}.mini-bar-track{flex:1;height:4px;background:var(--border);border-radius:99px;max-width:100px;overflow:hidden}.mini-bar-fill{height:100%;border-radius:99px;transition:width .4s}.mini-bar-label{font-family:var(--font-mono);font-size:11px;color:var(--text-3);min-width:30px}.by-type-list{display:flex;flex-direction:column;gap:6px}.by-type-row{display:flex;align-items:center;justify-content:space-between;font-size:13px;padding:8px 12px;background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border)}.by-type-name{color:var(--text-2);display:flex;align-items:center;gap:8px}.by-type-count{font-family:var(--font-mono);color:var(--brand);font-weight:600;font-size:13px}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.login-page{min-height:100vh;display:flex;background:var(--surface)}.login-left{flex:1;display:flex;align-items:center;justify-content:center;padding:60px;background:linear-gradient(145deg,#f0fdf4,#dcfce7 40%,#bbf7d0);position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2316A34A' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.login-brand{position:relative;max-width:400px}.login-brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-brand h1{font-size:38px;font-weight:800;color:var(--text);letter-spacing:-.02em;line-height:1.1;margin-bottom:12px}.login-brand h1 span{color:var(--brand)}.login-brand p{color:var(--text-2);font-size:15px;line-height:1.7}.login-features{margin-top:36px;display:flex;flex-direction:column;gap:13px}.login-feature{display:flex;align-items:flex-start;gap:11px;font-size:13.5px;color:var(--text-2)}.login-feature-icon{width:20px;height:20px;background:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.login-right{width:460px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:60px 48px;background:var(--surface)}.login-form-card{width:100%;max-width:340px}.login-form-card h2{font-size:24px;font-weight:700;color:var(--text);letter-spacing:-.01em;margin-bottom:6px}.login-form-card>p{color:var(--text-3);font-size:13.5px;margin-bottom:30px;line-height:1.6}.form-field{margin-bottom:16px}.form-field label{display:block;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-2);margin-bottom:7px}.form-field input{width:100%;height:42px;padding:10px 14px;font-size:14px}.login-btn{width:100%;height:42px;font-size:14px;font-weight:600;justify-content:center;margin-top:6px}.login-hint{margin-top:18px;font-size:12px;color:var(--text-3);text-align:center;line-height:1.7}.user-search-bar{display:flex;gap:10px;margin-bottom:24px}.user-search-bar input{flex:1;max-width:380px;height:40px;font-size:14px}.field-check-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--r-md);border:1px solid;font-size:13px;gap:12px}.field-check-pass{background:var(--green-bg);border-color:var(--green-border)}.field-check-fail{background:var(--red-bg);border-color:var(--red-border)}.expanded-row-cell{background:var(--surface-2);padding:14px 20px}.expanded-section-label{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px}@media (max-width: 1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.grid-2{grid-template-columns:1fr}}@media (max-width: 760px){:root{--sidebar-w: 56px}.logo-text-wrap,.nav-group-label,.nav-item span{display:none}.nav-item{justify-content:center;padding:9px}.sidebar-logo{padding:14px;justify-content:center}.logo-icon{margin:0}.page-body{padding:18px 16px 32px}.topbar{padding:0 16px}.login-left{display:none}.login-right{width:100%}}
