:root{--bg: #080c18;--bg1: #0d1221;--bg2: #111827;--bg3: #1a2236;--bg4: #1e2d45;--border: #1e3a5f;--border2: #2563eb30;--blue: #3b82f6;--blue-d: #1d4ed8;--cyan: #06b6d4;--green: #10b981;--amber: #f59e0b;--red: #ef4444;--purple: #8b5cf6;--text: #e2e8f0;--text2: #94a3b8;--text3: #475569;--text4: #1e3a5f}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:"Exo 2",system-ui,sans-serif;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg1)}::-webkit-scrollbar-thumb{background:#1e40af;border-radius:3px}.mono{font-family:Share Tech Mono,ui-monospace,monospace!important}.text-xs{font-size:11px}.text-sm{font-size:13px}.text-muted{color:var(--text2)}.text-dim{color:var(--text3)}input,select,textarea{background:var(--bg1);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:8px 12px;font-family:inherit;font-size:13px;width:100%;outline:none;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 2px #3b82f610}input::placeholder,textarea::placeholder{color:var(--text3)}select option{background:var(--bg2)}label{display:block;font-size:11px;font-weight:700;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}.btn{border:none;border-radius:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s;white-space:nowrap;line-height:1}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#1d4ed8;color:#fff}.btn-primary:hover:not(:disabled){background:#1e40af}.btn-success{background:#065f46;color:#6ee7b7;border:1px solid #10b98140}.btn-success:hover:not(:disabled){background:#047857}.btn-warning{background:#78350f;color:#fde68a;border:1px solid #f59e0b40}.btn-warning:hover:not(:disabled){background:#92400e}.btn-danger{background:#7f1d1d;color:#fca5a5;border:1px solid #ef444440}.btn-danger:hover:not(:disabled){background:#991b1b}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg3);color:var(--text)}.btn-cyan{background:#0e7490;color:#cffafe;border:1px solid #06b6d440}.btn-cyan:hover:not(:disabled){background:#155e75}.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}.btn-icon{padding:6px 8px}.btn-full{width:100%;justify-content:center}.card{background:var(--bg2);border:1px solid var(--border);border-radius:10px}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-body{padding:16px 18px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.4px;white-space:nowrap}.badge-green{color:#34d399;background:#064e3b40;border:1px solid #10b98140}.badge-amber{color:#fbbf24;background:#78350f40;border:1px solid #f59e0b40}.badge-blue{color:#60a5fa;background:#1e3a8a40;border:1px solid #3b82f640}.badge-red{color:#f87171;background:#7f1d1d40;border:1px solid #ef444440}.badge-purple{color:#c4b5fd;background:#4c1d9540;border:1px solid #8b5cf640}.badge-gray{color:var(--text2);background:var(--bg3);border:1px solid var(--border)}.badge-cyan{color:#67e8f9;background:#0e749040;border:1px solid #06b6d440}.tbl-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead{background:var(--bg1)}th{padding:9px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:10px 14px;border-bottom:1px solid #0f1f3560;vertical-align:middle}tbody tr:hover td{background:#0a1628;cursor:pointer}tbody tr:last-child td{border-bottom:none}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;min-width:220px;background:var(--bg1);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:54px;background:var(--bg1);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}.page-content{flex:1;overflow-y:auto;padding:20px}.nav-group{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);padding:14px 14px 4px}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 14px;margin:1px 6px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text2);transition:all .15s;border:1px solid transparent}.nav-item:hover{background:#0a1628;color:var(--text)}.nav-item.active{background:#1e3a8a20;color:#60a5fa;border-color:#1d4ed830}.nav-icon{font-size:15px;width:18px;text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:flex-start;justify-content:center;z-index:200;padding:20px 16px;overflow-y:auto}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:24px;width:100%;margin:auto;max-height:90vh;overflow-y:auto}.form-grid{display:grid;gap:14px}.fg-2{grid-template-columns:1fr 1fr}.fg-3{grid-template-columns:1fr 1fr 1fr}@media (max-width: 640px){.fg-2,.fg-3{grid-template-columns:1fr}}.field{display:flex;flex-direction:column}.conf-bar{height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}.conf-fill{height:100%;border-radius:3px;transition:width .3s}.chk-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg1);margin-bottom:8px;transition:border-color .15s,background .15s}.chk-item.ok{border-color:#10b98150;background:#064e3b18}.chk-item.nok{border-color:#ef444450;background:#7f1d1d18}.chk-item.na{opacity:.55}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px 20px}.stat-value{font-size:32px;font-weight:800;line-height:1;margin:4px 0}.stat-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3)}.stat-sub{font-size:12px;color:var(--text2);margin-top:4px}.section-title{font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--blue);margin-bottom:6px}.alert{padding:10px 14px;border-radius:7px;font-size:13px;display:flex;align-items:flex-start;gap:8px}.alert-error{background:#7f1d1d30;border:1px solid #ef444440;color:#fca5a5}.alert-success{background:#064e3b30;border:1px solid #10b98140;color:#6ee7b7}.alert-warn{background:#78350f30;border:1px solid #f59e0b40;color:#fde68a}.alert-info{background:#1e3a8a30;border:1px solid #3b82f640;color:#93c5fd}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:12px 18px;font-size:13px;z-index:500;display:flex;align-items:center;gap:8px;box-shadow:0 8px 30px #00000080;animation:slideIn .25s ease;max-width:360px}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 900px){.grid-4{grid-template-columns:1fr 1fr}}@media (max-width: 640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{display:none}.sidebar.mobile-open{display:flex;position:fixed;inset:0 auto 0 0;z-index:100;width:240px;box-shadow:4px 0 20px #0009}.page-content{padding:14px}}html.light{--bg: #f1f5f9;--bg1: #ffffff;--bg2: #f8fafc;--bg3: #eef2f7;--bg4: #e2e8f0;--border: #e2e8f0;--border2:#2563eb22;--blue: #2563eb;--cyan: #0891b2;--green: #059669;--amber: #d97706;--red: #dc2626;--purple: #7c3aed;--text: #1e293b;--text2: #475569;--text3: #94a3b8;--text4: #e2e8f0}html.light .sidebar{background:#0d1221!important;border-right-color:#1e3a5f!important}html.light .topbar{background:#fff;border-bottom-color:#e2e8f0}html.light .card,html.light .stat-card{box-shadow:0 1px 4px #0000000f}html.light .btn-ghost{background:#f8fafc;color:#475569;border-color:#e2e8f0}html.light .btn-ghost:hover:not(:disabled){background:#f1f5f9;color:#1e293b}html.light thead{background:#f8fafc}html.light th{color:#64748b;border-bottom-color:#e2e8f0}html.light td{border-bottom-color:#f1f5f9}html.light tbody tr:hover td{background:#f8fafc}html.light .badge-green{color:#166534;background:#dcfce7;border-color:#86efac}html.light .badge-amber{color:#92400e;background:#fef3c7;border-color:#fcd34d}html.light .badge-blue{color:#1e40af;background:#dbeafe;border-color:#93c5fd}html.light .badge-red{color:#991b1b;background:#fee2e2;border-color:#fca5a5}html.light .badge-cyan{color:#155e75;background:#cffafe;border-color:#67e8f9}html.light .badge-purple{color:#6b21a8;background:#f3e8ff;border-color:#d8b4fe}html.light .badge-gray{color:#374151;background:#f3f4f6;border-color:#d1d5db}html.light .chk-item{background:#f8fafc;border-color:#e2e8f0}html.light .chk-item.ok{background:#f0fdf4;border-color:#86efac80}html.light .chk-item.nok{background:#fef2f2;border-color:#fca5a580}html.light .alert-error{background:#fef2f2;border-color:#fca5a5;color:#dc2626}html.light .alert-success{background:#f0fdf4;border-color:#86efac;color:#16a34a}html.light .alert-warn{background:#fffbeb;border-color:#fcd34d;color:#b45309}html.light .alert-info{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}html.light .modal-backdrop{background:#0f172a66}html.light .toast{box-shadow:0 8px 30px #00000024}html.light .conf-bar{background:#e2e8f0}html.light ::-webkit-scrollbar-track{background:#f1f5f9}html.light ::-webkit-scrollbar-thumb{background:#94a3b8}html.light .nav-item:hover{background:#0a1628;color:#e2e8f0}html.light .nav-item.active{background:#1e3a8a30;color:#93c5fd;border-color:#1d4ed840}@media print{.sidebar,.topbar,.no-print{display:none!important}.main-area{overflow:visible}.page-content{padding:0;overflow:visible}body,html{background:#fff!important;color:#000!important;font-size:12px}.card{border:1px solid #ccc!important;background:#fff!important}table{border-collapse:collapse;width:100%}th,td{border:1px solid #ccc!important;padding:6px 8px!important;color:#000!important}thead{background:#f0f0f0!important}.badge{border:1px solid #999!important;color:#000!important;background:transparent!important}.print-page-break{page-break-before:always}}
