:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bg-main: #f4f5f9;--bg-card: #ffffff;--bg-sidebar: #ffffff;--border-color: #e8eaf0;--primary: #7c61ff;--primary-hover: #674ce6;--primary-light: #f0edff;--success: #10b981;--success-hover: #059669;--success-light: #ecfdf5;--warning: #f59e0b;--warning-light: #fef3c7;--danger: #ef4444;--danger-light: #fee2e2;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .03), 0 2px 8px rgba(0, 0, 0, .02);--shadow-lg: 0 10px 25px -5px rgba(124, 97, 255, .08), 0 8px 16px -8px rgba(0, 0, 0, .04);--shadow-card: 0 4px 20px rgba(0, 0, 0, .03);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition: all .25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-main);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-container{display:flex;flex-direction:column;height:100vh}.top-bar{display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-card);padding:12px 24px;border-bottom:1px solid var(--border-color);z-index:10;height:70px}.top-bar-left{display:flex;align-items:center;gap:16px}.logo-badge{background:linear-gradient(135deg,#7c61ff 0%,#a855f7 100%);color:#fff;padding:8px 16px;border-radius:var(--radius-md);font-weight:700;font-size:1.1rem;letter-spacing:.5px;box-shadow:0 4px 12px #7c61ff33;display:flex;align-items:center;gap:8px}.top-bar-right{display:flex;align-items:center;gap:12px}.status-pill{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:500}.status-pill.time{background-color:var(--primary-light);color:var(--primary)}.status-pill.duration{background-color:var(--warning-light);color:var(--warning)}.status-pill.online{background-color:var(--success-light);color:var(--success)}.profile-pill{display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:20px;background-color:#f1f5f9;border:1px solid var(--border-color);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.profile-pill:hover{background-color:#e2e8f0}.btn-logout{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;border:1px solid var(--border-color);background-color:var(--bg-card);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-logout:hover{background-color:var(--danger-light);color:var(--danger);border-color:var(--danger-light)}.main-layout{display:flex;flex:1;overflow:hidden;position:relative}.left-sidebar{width:260px;background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:24px 16px;overflow-y:auto}.sidebar-title{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:16px;padding-left:12px;font-weight:600}.sidebar-menu{list-style:none;display:flex;flex-direction:column;gap:6px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;font-size:.95rem;cursor:pointer;transition:var(--transition)}.sidebar-item:hover{background-color:#f8fafc;color:var(--text-primary)}.sidebar-item.active{background-color:var(--primary-light);color:var(--primary);font-weight:600}.right-nav-dock{width:64px;background-color:var(--bg-card);border-left:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;padding:24px 0;gap:16px;z-index:5}.dock-item{position:relative;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border:1px solid var(--border-color);background-color:var(--bg-card);box-shadow:var(--shadow-sm)}.dock-item:hover{color:var(--primary);border-color:var(--primary-light);box-shadow:0 4px 10px #7c61ff26;transform:translateY(-2px)}.dock-item.active{color:#fff;border-color:transparent;box-shadow:0 4px 12px #7c61ff4d}.dock-item.active-blue{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%)}.dock-item.active-purple{background:linear-gradient(135deg,#7c61ff 0%,#5b21b6 100%)}.dock-item.active-green{background:linear-gradient(135deg,#10b981 0%,#065f46 100%)}.dock-item.active-orange{background:linear-gradient(135deg,#f97316 0%,#c2410c 100%)}.dock-item-indicator{position:absolute;left:-1px;width:4px;height:16px;border-radius:0 4px 4px 0;background-color:var(--primary)}.content-area{flex:1;padding:32px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.page-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.page-subtitle{font-size:.95rem;color:var(--text-secondary);margin-top:4px}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:start}.card{background-color:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:24px;box-shadow:var(--shadow-card)}.card-title{font-size:1.1rem;font-weight:600;margin-bottom:18px;color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.form-select,.form-input{width:100%;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:#f8fafc;font-size:.95rem;color:var(--text-primary);outline:none;transition:var(--transition)}.form-select:focus,.form-input:focus{border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 3px #7c61ff26}.upload-dropzone{border:2px dashed #cbd5e1;border-radius:var(--radius-lg);padding:36px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;background-color:#f8fafc;transition:var(--transition);text-align:center}.upload-dropzone:hover,.upload-dropzone.dragging{border-color:var(--primary);background-color:var(--primary-light)}.upload-icon{color:var(--primary);background-color:#fff;padding:12px;border-radius:50%;box-shadow:var(--shadow-md);transition:var(--transition)}.upload-dropzone:hover .upload-icon{transform:scale(1.1)}.upload-text-main{font-size:.95rem;font-weight:600;color:var(--text-primary)}.upload-text-sub{font-size:.8rem;color:var(--text-muted)}.table-container{overflow-x:auto;margin-top:12px}.custom-table{width:100%;border-collapse:collapse;text-align:left}.custom-table th{padding:14px 16px;font-size:.8rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border-color);background-color:#f8fafc}.custom-table td{padding:16px;font-size:.9rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle}.custom-table tr:hover td{background-color:#f8fafc}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.badge-pending{background-color:#f1f5f9;color:var(--text-secondary)}.badge-processing{background-color:var(--primary-light);color:var(--primary)}.badge-completed{background-color:var(--success-light);color:var(--success)}.badge-failed{background-color:var(--danger-light);color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);font-weight:600;font-size:.95rem;cursor:pointer;border:none;transition:var(--transition)}.btn-primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 12px #7c61ff33}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:0 6px 16px #7c61ff4d}.btn-primary:disabled{background-color:var(--text-muted);cursor:not-allowed;box-shadow:none}.btn-icon{background-color:transparent;color:var(--text-secondary);padding:8px;border-radius:50%;border:1px solid var(--border-color)}.btn-icon:hover{background-color:#f1f5f9;color:var(--primary)}.spinner{border:2px solid #e2e8f0;border-top:2px solid var(--primary);border-radius:50%;width:16px;height:16px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease-out}.modal-content{background-color:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:24px;overflow-y:auto;font-size:.95rem;line-height:1.6}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.score-badge-large{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:70px;height:70px;border-radius:50%;background-color:var(--primary-light);color:var(--primary);font-weight:700;font-size:1.5rem;border:2px solid var(--primary);box-shadow:0 4px 10px #7c61ff26}.score-badge-large.success{background-color:var(--success-light);color:var(--success);border-color:var(--success)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.markdown-content h3{margin-top:16px;margin-bottom:8px;font-size:1.1rem;color:var(--text-primary)}.markdown-content p{margin-bottom:12px;color:var(--text-secondary)}.markdown-content ul,.markdown-content ol{margin-left:20px;margin-bottom:16px}.markdown-content li{margin-bottom:6px;color:var(--text-secondary)}.markdown-content strong{color:var(--text-primary)}.spin-animation{animation:spin 1s linear infinite}
