@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #f0f4f8;--bg-tertiary: #e2e8f0;--color-primary: #1e3a5f;--color-primary-hover: #2a4f7f;--color-primary-light: #3d6a9e;--color-accent: #3b82f6;--text-primary: #1a202c;--text-secondary: #4a5568;--text-muted: #6b7a8d;--text-inverse: #ffffff;--border-color: #d2d8e0;--color-success: #0d9488;--color-danger: #dc2626;--color-warning: #d97706;--color-info: #2563eb;--shadow-sm: 0 1px 2px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -2px rgba(0,0,0,.04);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.08), 0 10px 10px -5px rgba(0,0,0,.03);--shadow-inset: inset 0 2px 4px rgba(0,0,0,.06);--shadow-button: 0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.08);--shadow-card: 0 4px 12px rgba(0,0,0,.05), 0 1px 3px rgba(0,0,0,.03);--radius-sm: 6px;--radius: 8px;--radius-md: 10px;--radius-lg: 12px;--transition: all .2s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;height:100%}body,#app{min-height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.6;background:#edf1f7;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:var(--color-primary);color:var(--text-inverse)}a{color:var(--color-primary);text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-primary-hover);text-decoration:underline}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:#b0bec5;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 22px;border:1px solid transparent;border-radius:var(--radius);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none;box-shadow:var(--shadow-button);position:relative}.btn:active:not(:disabled){transform:translateY(1px);box-shadow:var(--shadow-inset)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary{background:var(--color-primary);color:var(--text-inverse);border-color:#17304f}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:#b8c0cc;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger{background:var(--color-danger);color:var(--text-inverse);border-color:#b91c1c}.btn-danger:hover:not(:disabled){background:#b91c1c;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success{background:var(--color-success);color:var(--text-inverse);border-color:#0b7e74}.btn-success:hover:not(:disabled){background:#0b7e74;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary);box-shadow:none}.btn-outline:hover:not(:disabled){background:var(--color-primary);color:var(--text-inverse);box-shadow:var(--shadow-button);transform:translateY(-1px)}.btn-sm{padding:6px 14px;font-size:13px;border-radius:var(--radius-sm)}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label,.form-group label{font-size:13px;font-weight:600;color:var(--text-primary);letter-spacing:.01em}.form-input,.form-select,textarea{padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:14px;outline:none;transition:var(--transition);box-shadow:var(--shadow-inset);width:100%}.form-input:focus,.form-select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:var(--shadow-inset),0 0 0 3px #1e3a5f1f}.form-input::placeholder,textarea::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234a5568' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}textarea{resize:vertical;min-height:80px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-full{grid-column:1 / -1}.table-container{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:var(--bg-primary)}table{width:100%;border-collapse:collapse}thead{background:#f1f5f9}th{padding:12px 16px;text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);border-bottom:2px solid var(--border-color)}td{padding:12px 16px;font-size:14px;border-bottom:1px solid #edf2f7;color:var(--text-primary)}tr:hover td{background:#f8fafc;color:var(--text-primary)}tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.02em;box-shadow:0 1px 2px #00000014}.badge-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.badge-danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.badge-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.badge-info{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.badge-default{background:#e0e7ff;color:var(--color-primary);border:1px solid #c7d2fe}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:32px;width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .25s ease}.modal h2{font-size:20px;font-weight:700;color:var(--color-primary);margin-bottom:20px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.spinner{width:22px;height:22px;border:2.5px solid var(--bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:14px 18px;border-radius:var(--radius);font-size:14px;margin-bottom:16px;border-left:4px solid transparent}.alert-success{background:#ecfdf5;color:#065f46;border-left-color:var(--color-success)}.alert-danger{background:#fef2f2;color:#991b1b;border-left-color:var(--color-danger)}.alert-warning{background:#fffbeb;color:#92400e;border-left-color:var(--color-warning)}.alert-info{background:#eff6ff;color:#1e40af;border-left-color:var(--color-info)}.file-upload{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:40px 20px;text-align:center;cursor:pointer;transition:var(--transition);color:var(--text-muted);background:var(--bg-secondary)}.file-upload:hover{border-color:var(--color-primary);background:#eaf0f8;color:var(--color-primary)}.file-upload input[type=file]{display:none}.tabs{display:flex;border-bottom:2px solid var(--border-color);gap:0;margin-bottom:24px}.tab{padding:10px 20px;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:var(--transition);background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}.tab:hover{color:var(--color-primary)}.tab.active,.tab.router-link-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.stat-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px 24px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-card);transition:var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card .stat-label{font-size:13px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.stat-card .stat-value{font-size:28px;font-weight:700;color:var(--color-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.page-header h1{font-size:24px;font-weight:700;color:var(--color-primary)}.page-header .subtitle{font-size:14px;color:var(--text-muted);margin-top:4px}.progress-bar{width:100%;height:14px;background:var(--bg-tertiary);border-radius:7px;overflow:hidden;box-shadow:var(--shadow-inset);border:1px solid var(--border-color)}.progress-fill{height:100%;background:var(--color-primary);border-radius:7px;transition:width .4s ease;box-shadow:inset 0 1px #fff3}.toggle{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer}.toggle input{display:none}.toggle-slider{position:absolute;inset:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:24px;transition:var(--transition);box-shadow:var(--shadow-inset)}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--bg-primary);border-radius:50%;transition:var(--transition);box-shadow:var(--shadow-button)}.toggle input:checked+.toggle-slider{background:var(--color-primary);border-color:#17304f}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state .icon{font-size:48px;margin-bottom:16px}.empty-state p{font-size:15px}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:16px}.mt-4{margin-top:24px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:16px}.mb-4{margin-bottom:24px}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:16px}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.form-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.page-header{flex-direction:column;align-items:flex-start}.modal{width:95%;padding:24px}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}@media print{body{background:#fff;color:#000}.sidebar,.btn,.modal-overlay,.file-upload,.tabs,.toggle,nav{display:none!important}.card,.stat-card,.table-container{box-shadow:none;border:1px solid #ccc;break-inside:avoid}}
