@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-200: #bfdbfe;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--blue-800: #1e40af;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg: #f0f4f8;--bg-sidebar: #030d1f;--bg-sidebar-hover: #0d2348;--bg-sidebar-active: #1d4ed8;--bg-white: #ffffff;--bg-input: #ffffff;--text-primary: #111827;--text-secondary: #4b5563;--text-muted: #9ca3af;--text-sidebar: #93afd4;--text-sidebar-active: #ffffff;--border: #e5e7eb;--border-focus: #2563eb;--accent: #2563eb;--accent-lt: #dbeafe;--success: #059669;--success-lt: #d1fae5;--warn: #d97706;--warn-lt: #fef3c7;--error: #dc2626;--error-lt: #fee2e2;--purple: #7c3aed;--purple-lt: #ede9fe;--gold: #f59e0b;--gold-lt: #fef3c7;--gold-dk: #d97706;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.05);--radius: 8px;--radius-sm: 5px;--radius-lg: 12px;--sans: "Inter", system-ui, sans-serif;--mono: "JetBrains Mono", "Courier New", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--text-primary);font-family:var(--sans);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-sidebar);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.main{margin-left:240px;flex:1;display:flex;flex-direction:column;min-height:100vh}.sidebar-logo{padding:18px 12px 14px;border-bottom:1px solid rgba(255,255,255,.08);text-align:center}.logo-eyebrow{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ffffff59;margin-bottom:5px}.logo-title{font-size:17px;font-weight:700;color:#fff;letter-spacing:-.01em}.logo-subtitle{font-size:11px;color:#ffffff59;margin-top:2px}.nav-section{padding:18px 16px 5px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#ffffff4d}.nav-link{display:flex;align-items:center;gap:10px;padding:8px 16px;color:var(--text-sidebar);text-decoration:none;font-size:13px;font-weight:400;cursor:pointer;border:none;background:none;width:100%;text-align:left;border-radius:0;transition:background .12s,color .12s;line-height:1.4}.nav-link:hover{background:var(--bg-sidebar-hover);color:#fff}.nav-link.active{background:var(--bg-sidebar-active);color:#fff;font-weight:500}.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0;opacity:.8}.nav-link.active .nav-icon{opacity:1}.page-header{background:var(--bg-white);border-bottom:1px solid var(--border);padding:20px 28px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm)}.page-header h2{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-subtitle{font-size:13px;color:var(--text-muted);margin-left:auto;background:var(--gray-100);padding:3px 10px;border-radius:20px;font-weight:500}.page-icon{width:36px;height:36px;background:var(--blue-50);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.page-body{padding:24px 28px;flex:1}.card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card+.card{margin-top:16px}.card-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--gray-50)}.card-header h3{font-size:13px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.card-body{padding:20px}.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:20px;gap:0}.tab{padding:9px 18px;font-size:13px;font-weight:500;cursor:pointer;border:none;background:none;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab:hover{color:var(--accent)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.form-grid{display:grid;gap:16px}.fg-2{grid-template-columns:1fr 1fr}.fg-3{grid-template-columns:1fr 1fr 1fr}.fg-4{grid-template-columns:1fr 1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:6px}label{font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.01em}.req{color:var(--error);margin-left:2px}.opt{font-weight:400;color:var(--text-muted);font-size:11px;margin-left:4px}input,select,textarea{background:var(--bg-input);border:1.5px solid var(--border);color:var(--text-primary);font-family:var(--sans);font-size:14px;padding:9px 12px;border-radius:var(--radius-sm);outline:none;transition:border-color .15s,box-shadow .15s;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1a}input::placeholder,textarea::placeholder{color:var(--gray-400);font-size:13px}input.err{border-color:var(--error)}.field-err{color:var(--error);font-size:11px;font-weight:500;margin-top:2px}.section-label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;font-family:var(--sans);font-size:13px;font-weight:600;border:1.5px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;text-decoration:none;white-space:nowrap;letter-spacing:-.01em}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 1px 2px #2563eb4d}.btn-primary:hover:not(:disabled){background:var(--blue-700);border-color:var(--blue-700)}.btn-secondary{background:var(--bg-white);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text-primary)}.btn-danger{background:var(--bg-white);color:var(--error);border-color:#fca5a5}.btn-danger:hover:not(:disabled){background:var(--error-lt);border-color:var(--error)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:#047857}.btn-sm{padding:6px 12px;font-size:12px}.btn-xs{padding:4px 9px;font-size:11px}.btn-lg{padding:12px 24px;font-size:15px}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.02em}.badge-success{background:var(--success-lt);color:#065f46}.badge-warning{background:var(--warn-lt);color:#92400e}.badge-error{background:var(--error-lt);color:#991b1b}.badge-pending{background:var(--blue-50);color:var(--blue-700)}.badge-admin{background:var(--purple-lt);color:#5b21b6}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;border-left:3px solid;margin:12px 0;display:flex;flex-direction:column;gap:3px}.alert-success{background:var(--success-lt);border-color:var(--success);color:#065f46}.alert-warning{background:var(--warn-lt);border-color:var(--warn);color:#92400e}.alert-error{background:var(--error-lt);border-color:var(--error);color:#991b1b}.alert-info{background:var(--blue-50);border-color:var(--accent);color:var(--blue-700)}.alert-title{font-weight:700;font-size:12px;letter-spacing:.02em}.result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:12px}.rf{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.rf-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:5px}.rf-value{font-family:var(--mono);font-size:14px;font-weight:600;color:var(--text-primary);word-break:break-all}.rf.mdn{border-color:var(--blue-200);background:var(--blue-50)}.rf.mdn .rf-label{color:var(--blue-600)}.rf.mdn .rf-value{font-size:20px;color:var(--accent)}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--gray-50);padding:10px 14px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:11px 14px;border-bottom:1px solid var(--gray-100);color:var(--text-primary);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--blue-50)}.mono-val{font-family:var(--mono);font-size:12px}.mdn-val{font-family:var(--mono);font-size:13px;color:var(--accent);font-weight:600}.warn-val{color:var(--warn);font-size:12px}.err-val{color:var(--error);font-size:12px}.dim-val{color:var(--text-muted)}.prog-outer{background:var(--gray-200);border-radius:20px;height:8px;overflow:hidden}.prog-inner{height:100%;background:linear-gradient(90deg,var(--accent),#60a5fa);border-radius:20px;transition:width .3s ease}.dropzone{border:2px dashed var(--gray-300);border-radius:var(--radius);padding:36px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--gray-50)}.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:var(--blue-50)}.dz-icon{font-size:32px;margin-bottom:10px}.dz-text{color:var(--text-secondary);font-size:14px;font-weight:500}.dz-sub{color:var(--text-muted);font-size:12px;margin-top:4px}.stats-row{display:flex;gap:12px;flex-wrap:wrap}.stat{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;min-width:120px;box-shadow:var(--shadow-sm)}.stat-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.stat-value{font-size:26px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.stat.a .stat-value{color:var(--accent)}.stat.s .stat-value{color:var(--success)}.stat.w .stat-value{color:var(--warn)}.stat.e .stat-value{color:var(--error)}.spinner{width:18px;height:18px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .65s linear infinite;display:inline-block;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.pagination{display:flex;align-items:center;gap:8px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border);background:var(--gray-50)}.page-info{font-size:12px;color:var(--text-muted);font-weight:500}.perm-card{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-white);cursor:pointer;transition:all .15s;font-size:13px;font-weight:500;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.perm-card:hover{border-color:var(--blue-200);background:var(--blue-50);color:var(--accent)}.perm-card.checked{border-color:var(--accent);background:var(--blue-50);color:var(--accent)}.perm-card.checked .perm-check{background:var(--accent);border-color:var(--accent)}.perm-check{width:18px;height:18px;border:2px solid var(--gray-300);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;font-size:11px;color:#fff}.mono{font-family:var(--mono)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-error{color:var(--error)}.text-warn{color:var(--warn)}.sm{font-size:12px}.xs{font-size:11px}.fw-600{font-weight:600}.fw-700{font-weight:700}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182780;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-header h3{font-size:16px;font-weight:700;color:var(--text-primary)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;flex-shrink:0;background:var(--gray-50)}.section-divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px}.section-divider-line{flex:1;height:1px;background:var(--border)}.section-divider-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:0 4px;white-space:nowrap}.callout{background:var(--blue-50);border:1px solid var(--blue-200);border-radius:var(--radius-sm);padding:12px 16px;font-size:13px;color:var(--blue-700);line-height:1.6}.callout strong{font-weight:600}.login-page{min-height:100vh;background:linear-gradient(160deg,#020b1a,#061530 35%,#0a2150 65%,#0d3070);display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:#fff;border-radius:var(--radius-lg);box-shadow:0 25px 60px #00000080;width:100%;max-width:420px;overflow:hidden}.login-card-header{background:linear-gradient(135deg,#020b1a,#0d2d6b);padding:32px 32px 28px;text-align:center}.login-card-body{padding:32px}.portal-footer{border-top:1px solid var(--border);background:var(--bg-white);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;margin-top:auto;flex-shrink:0}.portal-footer .footer-logo-wrap{display:flex;align-items:center;gap:12px}.portal-footer .footer-logo{height:38px;width:auto;display:block}.portal-footer .footer-brand-name{font-size:13px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;line-height:1.3}.portal-footer .footer-brand-sub{font-size:11px;color:var(--text-muted);margin-top:1px}.portal-footer .footer-right{font-size:11px;color:var(--text-muted);text-align:right;line-height:1.7}.sidebar-gold-bar{height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.5;margin:0 16px}
