@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary-50: #e0f7fa;--primary-100: #b2ebf2;--primary-200: #80deea;--primary-300: #4dd0e1;--primary-400: #26c6da;--primary-500: #00bcd4;--primary-600: #00acc1;--primary-700: #0097a7;--primary-800: #00838f;--primary-900: #006064;--accent-400: #00e5ff;--accent-500: #00b8d4;--accent-600: #0091ea;--success-400: #66bb6a;--success-500: #4caf50;--success-600: #43a047;--warning-400: #ffa726;--warning-500: #ff9800;--warning-600: #fb8c00;--error-400: #ef5350;--error-500: #f44336;--error-600: #e53935;--bg-primary: #0a0e1a;--bg-secondary: #0f1424;--bg-card: #141a2e;--bg-card-hover: #1a2240;--bg-elevated: #1e2642;--bg-surface: #232d4a;--bg-input: #0d1220;--text-primary: #e8eaf6;--text-secondary: #9fa8c7;--text-muted: #636d8c;--text-accent: #4dd0e1;--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-hover: rgba(77, 208, 225, .3);--border-focus: rgba(77, 208, 225, .6);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(0, 188, 212, .15);--shadow-glow-strong: 0 0 40px rgba(0, 188, 212, .25);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--glass-bg: rgba(20, 26, 46, .7);--glass-border: rgba(255, 255, 255, .08);--glass-blur: blur(20px)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;min-height:100vh}#root{min-height:100vh}a{color:var(--text-accent);text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:var(--text-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--primary-600)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow{0%,to{box-shadow:0 0 5px #00bcd433}50%{box-shadow:0 0 20px #00bcd466}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.animate-fade-in-up{animation:fadeInUp .5s ease-out forwards}.delay-1{animation-delay:.05s}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}.delay-4{animation-delay:.2s}.delay-5{animation-delay:.25s}.delay-6{animation-delay:.3s}.app-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-base)}.main-content{flex:1;padding:24px 28px;overflow-y:auto;max-height:calc(100vh - var(--header-height));background:var(--bg-primary)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base)}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:12px}.sidebar-logo-icon{width:38px;height:38px;background:linear-gradient(135deg,var(--primary-500),var(--accent-400));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;box-shadow:var(--shadow-glow);flex-shrink:0}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-text h1{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.sidebar-logo-text span{font-size:10px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.sidebar-section-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;padding:12px 12px 6px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:500;transition:all var(--transition-fast);cursor:pointer;position:relative;margin-bottom:2px;width:100%;text-align:left}.sidebar-item:hover{color:var(--text-primary);background:var(--bg-card)}.sidebar-item.active{color:var(--text-accent);background:#4dd0e114}.sidebar-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:linear-gradient(to bottom,var(--primary-400),var(--accent-400));border-radius:0 var(--radius-full) var(--radius-full) 0}.sidebar-item-icon{width:20px;height:20px;opacity:.7;flex-shrink:0}.sidebar-item.active .sidebar-item-icon{opacity:1}.sidebar-item-badge{margin-left:auto;background:var(--error-500);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-full);min-width:18px;text-align:center}.sidebar-footer{padding:12px 14px;border-top:1px solid var(--border-subtle)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--bg-card)}.sidebar-avatar{width:34px;height:34px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-600),var(--primary-400));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--text-muted)}.header{height:var(--header-height);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:16px}.header-title{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.header-subtitle{font-size:12px;color:var(--text-muted);margin-top:1px}.header-right{display:flex;align-items:center;gap:8px}.header-search{position:relative;margin-right:8px}.header-search input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-full);padding:8px 16px 8px 36px;color:var(--text-primary);width:240px;font-size:13px;transition:all var(--transition-fast)}.header-search input::placeholder{color:var(--text-muted)}.header-search input:focus{outline:none;border-color:var(--border-focus);background:var(--bg-card);width:300px;box-shadow:var(--shadow-glow)}.header-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:16px;height:16px}.header-icon-btn{width:38px;height:38px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast);position:relative}.header-icon-btn:hover{background:var(--bg-card);color:var(--text-primary)}.header-icon-btn .badge-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--error-500);border-radius:var(--radius-full);border:2px solid var(--bg-secondary);animation:pulse 2s infinite}.header-divider{width:1px;height:28px;background:var(--border-subtle);margin:0 4px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;animation:fadeIn .3s ease-out}.page-header-info h2{font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-header-info p{font-size:13px;color:var(--text-muted);margin-top:2px}.page-actions{display:flex;gap:10px}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius-md);font-size:13px;font-weight:600;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:0 2px 8px #00bcd44d}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-400),var(--primary-500));box-shadow:0 4px 16px #00bcd466;transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);border:1px solid var(--border-default);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-hover);color:var(--text-primary)}.btn-ghost{color:var(--text-secondary);padding:8px 14px}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.btn-danger{background:#f4433626;color:var(--error-400);border:1px solid rgba(244,67,54,.2)}.btn-danger:hover{background:#f4433640}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{width:34px;height:34px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:11px;color:var(--text-muted);margin-top:2px}.stat-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;transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary-500),transparent);opacity:0;transition:opacity var(--transition-base)}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.stat-card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.stat-card-icon.blue{background:#00bcd41a;color:var(--primary-400)}.stat-card-icon.green{background:#4caf501a;color:var(--success-400)}.stat-card-icon.amber{background:#ff98001a;color:var(--warning-400)}.stat-card-icon.red{background:#f443361a;color:var(--error-400)}.stat-card-icon.purple{background:#9c27b01a;color:#ab47bc}.stat-card-value{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-.03em}.stat-card-label{font-size:12px;color:var(--text-muted);margin-top:4px}.stat-card-trend{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-top:8px}.stat-card-trend.up{background:#4caf501a;color:var(--success-400)}.stat-card-trend.down{background:#f443361a;color:var(--error-400)}.charts-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:24px}.charts-grid-equal{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-card)}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap;position:sticky;top:0}.data-table td{padding:12px 16px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-card-hover)}.data-table tr{transition:background var(--transition-fast)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;white-space:nowrap}.status-badge.verified,.status-badge.approved,.status-badge.released,.status-badge.complete,.status-badge.active-status,.status-badge.online{background:#4caf501f;color:var(--success-400)}.status-badge.pending_review,.status-badge.pending_signature,.status-badge.pending_release,.status-badge.under_review,.status-badge.in_progress,.status-badge.warning{background:#ff98001f;color:var(--warning-400)}.status-badge.flagged,.status-badge.rejected,.status-badge.critical,.status-badge.overdue{background:#f443361f;color:var(--error-400)}.status-badge.draft,.status-badge.pending,.status-badge.inactive,.status-badge.offline{background:#9e9e9e1f;color:var(--text-muted)}.status-badge.info{background:#00bcd41f;color:var(--primary-300)}.status-dot{width:6px;height:6px;border-radius:var(--radius-full);background:currentColor}.tabs{display:flex;gap:2px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:3px;margin-bottom:20px;width:fit-content}.tab{padding:8px 18px;font-size:13px;font-weight:500;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.tab:hover{color:var(--text-secondary)}.tab.active{background:var(--bg-card);color:var(--text-accent);box-shadow:var(--shadow-sm)}.filters-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.filter-select{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:8px 30px 8px 14px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all var(--transition-fast);appearance:none;-webkit-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='%239fa8c7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.filter-select:hover{border-color:var(--border-hover)}.filter-select:focus{outline:none;border-color:var(--border-focus)}.filter-search{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:8px 14px;color:var(--text-primary);font-size:13px;transition:all var(--transition-fast);width:250px}.filter-search:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--shadow-glow)}.filter-search::placeholder{color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state-icon{width:64px;height:64px;border-radius:var(--radius-xl);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:16px}.empty-state h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.empty-state p{font-size:13px;color:var(--text-muted);max-width:360px}.compliance-ring{position:relative;width:120px;height:120px}.compliance-ring-value{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.compliance-ring-number{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1}.compliance-ring-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}.checklist-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.checklist-item:last-child{border-bottom:none}.checklist-icon{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.checklist-icon.complete{background:#4caf501f;color:var(--success-400)}.checklist-icon.in_progress{background:#ff98001f;color:var(--warning-400)}.checklist-icon.warning{background:#f443361f;color:var(--error-400)}.checklist-icon.pending{background:#9e9e9e1f;color:var(--text-muted)}.checklist-text{flex:1;font-size:13px;color:var(--text-secondary)}.checklist-tag{font-size:10px;padding:3px 8px;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-muted);white-space:nowrap}.progress-bar-container{width:100%;height:6px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width 1s ease-out}.progress-bar-fill.high{background:linear-gradient(90deg,var(--success-500),var(--success-400))}.progress-bar-fill.medium{background:linear-gradient(90deg,var(--warning-500),var(--warning-400))}.progress-bar-fill.low{background:linear-gradient(90deg,var(--error-500),var(--error-400))}.activity-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.activity-item:last-child{border-bottom:none}.activity-icon{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon.upload{background:#00bcd41a;color:var(--primary-400)}.activity-icon.approve{background:#4caf501a;color:var(--success-400)}.activity-icon.edit{background:#ff98001a;color:var(--warning-400)}.activity-icon.alert{background:#f443361a;color:var(--error-400)}.activity-icon.signature{background:#9c27b01a;color:#ab47bc}.activity-content{flex:1;min-width:0}.activity-title{font-size:13px;color:var(--text-primary);font-weight:500}.activity-title strong{color:var(--text-accent);font-weight:600}.activity-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.modal{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:480px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:scaleIn .25s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 12px}.modal-header h3{font-size:17px;font-weight:700;color:var(--text-primary)}.modal-body{padding:8px 24px 20px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:12px 24px 20px;border-top:1px solid var(--border-subtle)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-input{width:100%;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px 14px;color:var(--text-primary);font-size:13px;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #4dd0e11a}.form-input::placeholder{color:var(--text-muted)}.form-textarea{min-height:80px;resize:vertical}.upload-zone{border:2px dashed var(--border-default);border-radius:var(--radius-lg);padding:40px;text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--bg-secondary)}.upload-zone:hover{border-color:var(--primary-500);background:#00bcd408;box-shadow:var(--shadow-glow)}.upload-zone-icon{width:56px;height:56px;border-radius:var(--radius-xl);background:#00bcd41a;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--primary-400)}.upload-zone h3{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.upload-zone p{font-size:12px;color:var(--text-muted)}.upload-zone .highlight{color:var(--primary-400);font-weight:600}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.doc-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-base);cursor:pointer}.doc-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.doc-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.doc-card-icon{width:40px;height:40px;border-radius:var(--radius-md);background:#00bcd41a;display:flex;align-items:center;justify-content:center;color:var(--primary-400);flex-shrink:0}.doc-card-icon.sop{background:#00bcd41a;color:var(--primary-400)}.doc-card-icon.template{background:#9c27b01a;color:#ab47bc}.doc-card-icon.protocol{background:#4caf501a;color:var(--success-400)}.doc-card-icon.deviation{background:#ff98001a;color:var(--warning-400)}.doc-card-icon.capa{background:#f443361a;color:var(--error-400)}.doc-card-icon.report{background:#2196f31a;color:#42a5f5}.doc-card-title{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3}.doc-card-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--text-muted);margin-top:8px}.doc-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid var(--border-subtle)}.batch-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-base)}.batch-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.batch-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.batch-id{font-size:12px;font-weight:700;color:var(--primary-400);font-family:SF Mono,Cascadia Code,Fira Code,monospace}.batch-product{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.batch-stage{font-size:12px;color:var(--text-muted);margin-bottom:14px}.batch-stats{display:flex;gap:20px;margin-bottom:14px}.batch-stat{display:flex;flex-direction:column}.batch-stat-value{font-size:16px;font-weight:700;color:var(--text-primary)}.batch-stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:scaleIn .2s ease-out;z-index:200;overflow:hidden}.notification-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-subtle)}.notification-dropdown-header h4{font-size:14px;font-weight:600;color:var(--text-primary)}.notification-list{max-height:360px;overflow-y:auto}.notification-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);cursor:pointer}.notification-item:hover{background:var(--bg-card-hover)}.notification-item.unread{background:#00bcd408}.notification-icon{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-icon.critical{background:#f443361a;color:var(--error-400)}.notification-icon.warning{background:#ff98001a;color:var(--warning-400)}.notification-icon.info{background:#00bcd41a;color:var(--primary-400)}.notification-text h5{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.notification-text p{font-size:12px;color:var(--text-muted)}.notification-time{font-size:10px;color:var(--text-muted);white-space:nowrap;margin-left:auto;margin-top:2px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(0,188,212,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(0,145,234,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 100%,rgba(0,96,100,.08) 0%,transparent 50%)}.login-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:40px;width:420px;max-width:90vw;position:relative;z-index:1;box-shadow:var(--shadow-lg);animation:scaleIn .4s ease-out}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:56px;height:56px;background:linear-gradient(135deg,var(--primary-500),var(--accent-400));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;margin:0 auto 16px;box-shadow:var(--shadow-glow-strong)}.login-header h2{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.login-header p{font-size:13px;color:var(--text-muted)}.login-form .form-group{margin-bottom:18px}.login-form .btn-primary{width:100%;padding:12px;font-size:14px;margin-top:8px}.login-footer{text-align:center;margin-top:20px;font-size:12px;color:var(--text-muted)}.settings-grid{display:grid;grid-template-columns:240px 1fr;gap:24px}.settings-nav{display:flex;flex-direction:column;gap:2px}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.settings-nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.settings-nav-item.active{background:#4dd0e114;color:var(--text-accent)}.settings-content{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:28px}.settings-section{margin-bottom:28px}.settings-section:last-child{margin-bottom:0}.settings-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.settings-section p{font-size:12px;color:var(--text-muted);margin-bottom:16px}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.settings-row:last-child{border-bottom:none}.settings-row-info h4{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.settings-row-info p{font-size:12px;color:var(--text-muted);margin-bottom:0}.toggle{position:relative;width:44px;height:24px;background:var(--bg-elevated);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast);border:1px solid var(--border-subtle)}.toggle.active{background:var(--primary-600);border-color:var(--primary-500)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:var(--radius-full);transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.toggle.active:after{transform:translate(20px)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-subtle)}.recharts-text{fill:var(--text-muted);font-size:11px}.custom-tooltip{background:var(--bg-elevated)!important;border:1px solid var(--border-default)!important;border-radius:var(--radius-md)!important;padding:10px 14px!important;box-shadow:var(--shadow-lg)!important}.custom-tooltip .label{font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.custom-tooltip .value{font-size:11px;color:var(--text-secondary)}@media(max-width:1200px){.stat-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.charts-grid-equal{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.main-wrapper{margin-left:0}.stat-grid,.doc-grid{grid-template-columns:1fr}.header-search input{width:160px}.settings-grid{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--bg-primary)}.login-bg{position:absolute;inset:0;pointer-events:none;z-index:0}.login-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.3;pointer-events:none}.login-orb-1{width:500px;height:500px;background:var(--primary-600);top:-150px;right:-100px;animation:loginFloat1 12s ease-in-out infinite}.login-orb-2{width:400px;height:400px;background:var(--accent-600);bottom:-100px;left:-100px;animation:loginFloat2 15s ease-in-out infinite}.login-orb-3{width:300px;height:300px;background:#7c4dff;top:50%;left:50%;transform:translate(-50%,-50%);animation:loginFloat3 10s ease-in-out infinite}@keyframes loginFloat1{0%,to{transform:translate(0)}50%{transform:translate(-40px,30px)}}@keyframes loginFloat2{0%,to{transform:translate(0)}50%{transform:translate(30px,-30px)}}@keyframes loginFloat3{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.15)}}.login-container{position:relative;z-index:10;display:flex;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg),var(--shadow-glow);max-width:820px;width:90%;animation:fadeInUp .6s ease-out}.login-branding{flex:1;padding:40px 36px;background:linear-gradient(135deg,#00bcd414,#0091ea0d);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;justify-content:center}.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:12px;color:var(--primary-400)}.login-logo h1{font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-.03em}.login-tagline{font-size:14px;color:var(--text-secondary);margin-bottom:32px}.login-features{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}.login-feature{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.login-feature svg{color:var(--primary-400);flex-shrink:0}.login-compliance-note{font-size:11px;color:var(--text-muted);line-height:1.6;padding:12px;background:#0003;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.login-form-panel{flex:1;padding:40px 36px;display:flex;flex-direction:column;justify-content:center}.login-form-panel h2{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.login-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:24px}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f443361a;border:1px solid rgba(244,67,54,.2);border-radius:var(--radius-md);color:var(--error-400);font-size:13px;margin-bottom:16px;animation:fadeIn .3s ease-out}.login-form-panel .form-group{margin-bottom:18px}.login-form-panel label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.login-form-panel .input-wrapper{position:relative;display:flex;align-items:center}.login-form-panel .input-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none;z-index:1}.login-form-panel input[type=email],.login-form-panel input[type=password],.login-form-panel input[type=text]{width:100%;padding:11px 14px 11px 42px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.login-form-panel input:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--shadow-glow);background:var(--bg-card)}.login-form-panel input::placeholder{color:var(--text-muted)}.login-form-panel input:disabled{opacity:.6;cursor:not-allowed}.password-toggle{position:absolute;right:10px;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;z-index:1}.password-toggle:hover{color:var(--text-secondary)}.login-btn{width:100%;padding:12px;font-size:14px;font-weight:700;justify-content:center;margin-top:6px}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none!important}.login-spinner{display:inline-flex;align-items:center;gap:8px}.login-spinner:before{content:"";width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.login-demo-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-subtle);text-align:center}.login-demo-btn{width:100%;justify-content:center;background:#00bcd40d;border:1px dashed var(--border-default);color:var(--text-accent);margin-bottom:8px}.login-demo-btn:hover{background:#00bcd41a;border-color:var(--border-hover)}.login-demo-hint{font-size:11px;color:var(--text-muted)}.login-footer{text-align:center;font-size:10px;color:var(--text-muted);margin-top:20px;text-transform:uppercase;letter-spacing:.08em}.spin{animation:spin 1s linear infinite}@media(max-width:700px){.login-container{flex-direction:column;max-width:400px}.login-branding{border-right:none;border-bottom:1px solid var(--glass-border);padding:28px 24px}.login-form-panel{padding:28px 24px}}
