@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary: #080810;--bg-secondary: #0f0f1a;--bg-card: #141422;--bg-card-hover: #1a1a2e;--bg-elevated: #1e1e32;--bg-glass: rgba(20, 20, 34, .75);--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-hover: rgba(255, 255, 255, .15);--text-primary: #f0f0f5;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-on-accent: #fff;--accent-blue: #3b82f6;--accent-blue-soft: rgba(59, 130, 246, .15);--accent-green: #10b981;--accent-green-soft: rgba(16, 185, 129, .15);--accent-gold: #f59e0b;--accent-gold-soft: rgba(245, 158, 11, .15);--accent-red: #ef4444;--accent-red-soft: rgba(239, 68, 68, .15);--accent-purple: #8b5cf6;--accent-purple-soft: rgba(139, 92, 246, .15);--gradient-primary: linear-gradient(135deg, #3b82f6, #8b5cf6);--gradient-success: linear-gradient(135deg, #10b981, #06b6d4);--gradient-hero: linear-gradient(135deg, #0f0f1a 0%, #141428 50%, #1a1a30 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(59, 130, 246, .2);--sidebar-width: 260px;--header-height: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:transform var(--transition-smooth)}.sidebar-header{padding:20px;border-bottom:1px solid var(--border-subtle)}.sidebar-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}.sidebar-logo-icon{width:38px;height:38px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:var(--shadow-glow)}.sidebar-logo-text{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.sidebar-logo-sub{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.sidebar-nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.nav-item.active{background:var(--accent-blue-soft);color:var(--accent-blue)}.nav-item-icon{font-size:16px;width:20px;text-align:center}.sidebar-footer{padding:16px;border-top:1px solid var(--border-subtle)}.user-info{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff}.user-name{font-size:12px;font-weight:600;color:var(--text-primary)}.user-email{font-size:10px;color:var(--text-muted)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.page-header{padding:24px 32px;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);position:sticky;top:0;z-index:30;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.page-title{font-size:22px;font-weight:700;letter-spacing:-.5px}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:2px}.page-content{padding:24px 32px}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-normal)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.card-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden;transition:all var(--transition-normal)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stat-card.blue:before{background:var(--accent-blue)}.stat-card.green:before{background:var(--accent-green)}.stat-card.gold:before{background:var(--accent-gold)}.stat-card.purple:before{background:var(--accent-purple)}.stat-card.red:before{background:var(--accent-red)}.stat-card:hover{transform:translateY(-2px);border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.stat-icon{font-size:20px;margin-bottom:8px;display:inline-block}.stat-value{font-size:28px;font-weight:800;letter-spacing:-1px;line-height:1}.stat-label{font-size:12px;color:var(--text-secondary);margin-top:4px;font-weight:500}.data-table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:12px 16px;background:var(--bg-elevated);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-secondary);text-align:left;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.data-table td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast)}.data-table tr:hover td{background:var(--bg-card-hover)}.data-table tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.3px}.badge-done{background:var(--accent-green-soft);color:var(--accent-green)}.badge-processing{background:var(--accent-blue-soft);color:var(--accent-blue);animation:pulse 2s infinite}.badge-pending{background:var(--accent-gold-soft);color:var(--accent-gold)}.badge-failed{background:var(--accent-red-soft);color:var(--accent-red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all var(--transition-normal);text-decoration:none;white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-hover)}.btn-success{background:var(--gradient-success);color:#fff}.btn-danger{background:var(--accent-red-soft);color:var(--accent-red);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover:not(:disabled){background:#ef444433}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-card)}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:14px 28px;font-size:15px}.btn-icon{padding:8px;width:36px;height:36px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.form-input{width:100%;padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:inherit;transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-soft)}.form-input::placeholder{color:var(--text-muted)}.file-upload{border:2px dashed var(--border-default);border-radius:var(--radius-lg);padding:40px 20px;text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--bg-card)}.file-upload:hover,.file-upload.drag-over{border-color:var(--accent-blue);background:var(--accent-blue-soft)}.file-upload-icon{font-size:40px;margin-bottom:12px;display:block}.file-upload-text{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.file-upload-hint{font-size:11px;color:var(--text-muted)}.file-upload-selected{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--accent-green-soft);border-radius:var(--radius-sm);margin-top:12px}.file-upload-selected span{font-size:13px;color:var(--accent-green);font-weight:500}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-hero);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(59,130,246,.08),transparent 70%);top:-200px;right:-200px}.login-page:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.06),transparent 70%);bottom:-100px;left:-100px}.login-card{width:420px;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-lg);z-index:1}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{width:56px;height:56px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:inline-flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:16px;box-shadow:var(--shadow-glow)}.login-logo h1{font-size:20px;font-weight:700;letter-spacing:-.5px}.login-logo p{font-size:13px;color:var(--text-secondary);margin-top:4px}.login-error{background:var(--accent-red-soft);border:1px solid rgba(239,68,68,.2);color:var(--accent-red);padding:10px 14px;border-radius:var(--radius-sm);font-size:12px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.report-viewer{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.report-viewer iframe{width:100%;min-height:80vh;border:none}.report-actions{display:flex;gap:8px;margin-bottom:16px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-default);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;inset:0;background:#080810cc;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-text{font-size:14px;color:var(--text-secondary)}.empty-state{text-align:center;padding:60px 20px}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-title{font-size:18px;font-weight:600;margin-bottom:8px}.empty-state-desc{font-size:13px;color:var(--text-secondary);max-width:400px;margin:0 auto 20px}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.detail-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.summary-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;text-align:center}.summary-card-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}.summary-card-value{font-size:24px;font-weight:800;letter-spacing:-.5px}.summary-card.highlight{background:var(--accent-gold-soft);border-color:#f59e0b33}.summary-card.highlight .summary-card-value{color:var(--accent-gold)}.summary-card.success{background:var(--accent-green-soft);border-color:#10b98133}.summary-card.success .summary-card-value{color:var(--accent-green)}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;z-index:200;animation:slideUp .3s ease;box-shadow:var(--shadow-lg)}.toast-success{background:var(--accent-green);color:#fff}.toast-error{background:var(--accent-red);color:#fff}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.filter-bar{display:flex;gap:12px;align-items:center;margin-bottom:16px}.filter-bar .form-input{max-width:300px}.filter-info{font-size:12px;color:var(--text-secondary);margin-bottom:12px}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.page-info{font-size:13px;color:var(--text-secondary)}.report-modal{position:fixed;inset:0;background:#080810d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.report-modal-content{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:1100px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.report-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.report-modal-header h3{font-size:16px;font-weight:700;color:#1a1a2e}.report-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:4px 8px;border-radius:var(--radius-sm)}.report-modal-close:hover{background:#f3f4f6;color:#1a1a2e}.report-modal-body{flex:1;overflow:auto;padding:0}.report-modal-body iframe{width:100%;min-height:80vh;border:none}@media(max-width:1024px){.stats-grid,.detail-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.stats-grid,.detail-summary{grid-template-columns:1fr}.page-content,.page-header{padding:16px}.page-title{font-size:18px}.detail-header{flex-direction:column;gap:12px}.report-modal{padding:0}.report-modal-content{max-width:100%;max-height:100vh;height:100vh;border-radius:0}.report-modal-body{-webkit-overflow-scrolling:touch}.report-modal-header{padding:12px 16px}.report-modal-header h3{font-size:14px}}
