*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f0f2f5;color:#1a1a2e}a{color:inherit;text-decoration:none}input,select,button,textarea{font:inherit}.app-layout{display:flex;min-height:100vh}.sidebar{width:220px;flex-shrink:0;background:#1a1a2e;color:#e0e0e0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{padding:20px 18px;font-size:1.1rem;font-weight:700;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:8px;color:#fff}.sidebar-logo-img{width:32px;height:32px;border-radius:6px;object-fit:cover}.sidebar-nav{flex:1;padding:12px 0}.nav-link{display:block;padding:10px 18px;color:#b0b8c8;transition:background .15s,color .15s}.nav-link:hover{background:#ffffff12;color:#fff}.nav-link.active{background:#4f46e5;color:#fff}.sidebar-user{padding:14px 18px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:6px}.user-name{font-weight:600;color:#fff;font-size:.9rem}.user-role{font-size:.8rem;color:#8892a4}.btn-logout{margin-top:4px;padding:6px 10px;background:transparent;border:1px solid rgba(255,255,255,.2);color:#b0b8c8;border-radius:6px;cursor:pointer;transition:.15s}.btn-logout:hover{background:#ffffff1a;color:#fff}.main-content{flex:1;padding:28px 32px;overflow-y:auto}.page{max-width:1200px}.page-title{font-size:1.6rem;font-weight:700;margin-bottom:20px;color:#1a1a2e}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header .page-title{margin-bottom:0}.header-actions{display:flex;gap:10px}.card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 4px #0000000f;margin-bottom:20px}.section-title{font-size:1rem;font-weight:600;margin-bottom:16px;color:#4f46e5}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;border:none;cursor:pointer;font-weight:500;transition:.15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:#4f46e5;color:#fff}.btn-primary:hover:not(:disabled){background:#4338ca}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover:not(:disabled){background:#d1d5db}.btn-success{background:#16a34a;color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-full{width:100%;justify-content:center}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.form-group label{font-weight:500;font-size:.9rem;color:#374151}.form-group input,.form-group select,.form-group textarea{padding:9px 12px;border:1px solid #d1d5db;border-radius:7px;background:#fff;transition:border-color .15s;width:100%}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.hint{font-size:.8rem;color:#6b7280}.form-row{display:grid;grid-template-columns:1fr 1fr 180px;gap:16px;margin-bottom:14px}.form-actions{display:flex;gap:12px;margin-top:4px;flex-wrap:wrap}.settings-form{max-width:560px}.alert{padding:10px 14px;border-radius:7px;margin-bottom:16px;font-size:.9rem}.alert-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.78rem;font-weight:600}.badge-green{background:#dcfce7;color:#166534}.badge-red{background:#fee2e2;color:#991b1b}.badge-yellow{background:#fef9c3;color:#713f12}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:#f3f4f6;color:#6b7280}.count-badge{background:#e0e7ff;color:#4338ca;padding:3px 10px;border-radius:12px;font-size:.85rem;font-weight:600}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb}.data-table{width:100%;border-collapse:collapse;font-size:.88rem}.data-table th{background:#f8fafc;text-align:left;padding:10px 12px;font-weight:600;border-bottom:1px solid #e5e7eb;white-space:nowrap;color:#374151}.data-table td{padding:9px 12px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8fafc}.data-table tr.row-selected td{background:#eef2ff}.empty-row{text-align:center;color:#9ca3af;padding:30px!important}.empty-row a{color:#4f46e5;text-decoration:underline}code{background:#f1f5f9;padding:1px 5px;border-radius:4px;font-size:.83rem;font-family:monospace}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.search-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:7px;width:280px}.search-input:focus{outline:none;border-color:#4f46e5}.filters{display:flex;align-items:center;gap:12px;padding:14px 18px!important;flex-wrap:wrap}.filters select,.filters input[type=date]{padding:7px 10px;border:1px solid #d1d5db;border-radius:7px}.table-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}.table-actions{display:flex;align-items:center;gap:12px}.checkbox-all{display:flex;align-items:center;gap:6px;cursor:pointer;font-weight:500}.status-select{padding:4px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:.82rem}.pagination{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:#fff;border-radius:10px;padding:20px;text-align:center;box-shadow:0 1px 4px #0000000f;border-top:4px solid #4f46e5}.stat-card.stat-green{border-top-color:#16a34a}.stat-card.stat-red{border-top-color:#dc2626}.stat-card.stat-yellow{border-top-color:#ca8a04}.stat-value{font-size:2.2rem;font-weight:700;color:#1a1a2e}.stat-label{font-size:.85rem;color:#6b7280;margin-top:4px}.dashboard-links{display:flex;gap:14px;flex-wrap:wrap}.quick-link{display:flex;align-items:center;gap:10px;background:#fff;padding:16px 20px;border-radius:10px;box-shadow:0 1px 4px #0000000f;font-weight:500;transition:box-shadow .15s,transform .15s}.quick-link:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.ql-icon{font-size:1.4rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e)}.login-card{background:#fff;border-radius:14px;padding:40px 36px;width:100%;max-width:380px;box-shadow:0 20px 60px #0000004d}.login-logo-img{display:block;width:72px;height:72px;border-radius:14px;object-fit:cover;margin:0 auto 8px}.login-title{text-align:center;font-size:1.4rem;font-weight:700;margin-bottom:4px}.login-subtitle{text-align:center;color:#6b7280;font-size:.9rem;margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:14px}.loading{text-align:center;padding:40px;color:#6b7280;font-size:1rem}.search-form{margin-bottom:20px}.btn-sm{padding:4px 10px;font-size:.82rem}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:#fff;border-radius:12px;padding:28px 32px;width:100%;max-width:520px;box-shadow:0 20px 60px #00000040;max-height:90vh;overflow-y:auto}.modal-card.modal-sm{max-width:380px}.modal-card.modal-lg{max-width:780px}.modal-title{font-size:1.2rem;font-weight:700;margin-bottom:18px;color:#1a1a2e}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.password-display{display:flex;align-items:center;gap:10px;background:#f1f5f9;padding:12px 16px;border-radius:8px}.password-text{font-size:1.2rem;letter-spacing:1px;flex:1}.driver-card-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.driver-name-link{color:#4f46e5;cursor:pointer;font-weight:500}.driver-name-link:hover{text-decoration:underline}.driver-info-banner{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:22px 28px;border-radius:12px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.driver-info-banner h2{color:#fff}.driver-info-name{margin:0 0 6px;font-size:1.5rem}.driver-info-details{opacity:.9;font-size:.9rem}.driver-info-details strong{font-weight:600}.info-box{background:#e0e7ff;border-left:4px solid #4f46e5;padding:12px 18px;border-radius:8px;margin-bottom:16px;font-size:.9rem;color:#312e81}.form-row-3{display:grid;grid-template-columns:1fr 1fr 180px;gap:14px;margin-bottom:14px}.tabs{display:flex;gap:4px;margin-bottom:20px;background:#f1f5f9;border-radius:10px;padding:4px}.tab{flex:1;padding:9px 16px;background:transparent;border:none;border-radius:8px;cursor:pointer;font-weight:500;color:#6b7280;transition:.15s}.tab:hover{color:#1a1a2e}.tab-active{background:#fff;color:#4f46e5;box-shadow:0 1px 3px #00000014;font-weight:600}.pos-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-group textarea{padding:9px 12px;border:1px solid #d1d5db;border-radius:7px;resize:vertical}.docs-section p{font-size:.92rem;color:#374151}.docs-list{padding-left:20px;font-size:.9rem;line-height:1.8;color:#374151}.docs-list li{margin-bottom:4px}.code-block{background:#1e293b;color:#e2e8f0;padding:16px 20px;border-radius:8px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.82rem;line-height:1.6;overflow-x:auto;white-space:pre;margin:0}.docs-steps{display:flex;flex-direction:column;gap:16px}.docs-step{display:flex;gap:14px;align-items:flex-start}.step-num{min-width:30px;height:30px;background:#4f46e5;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0;margin-top:2px}.kb-layout{display:flex;gap:20px;min-height:600px}.kb-sidebar{width:320px;flex-shrink:0;display:flex;flex-direction:column;gap:16px}.kb-sidebar-section{background:#fff;border-radius:10px;padding:16px;box-shadow:0 1px 4px #0000000f}.kb-sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.kb-sidebar-header h3{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0}.kb-content{flex:1;min-width:0}.kb-categories-list{display:flex;flex-direction:column;gap:4px}.kb-category-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s}.kb-category-item:hover{background:#f1f5f9}.kb-category-item.active{background:#e0e7ff}.kb-category-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.kb-category-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kb-category-count{background:#e0e7ff;color:#4338ca;font-size:.75rem;font-weight:600;padding:1px 7px;border-radius:10px;flex-shrink:0}.kb-category-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.kb-category-item:hover .kb-category-actions{opacity:1}.kb-articles-list{display:flex;flex-direction:column;gap:4px;max-height:400px;overflow-y:auto}.kb-article-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s}.kb-article-item:hover{background:#f1f5f9}.kb-article-item.active{background:#e0e7ff}.kb-article-info{flex:1;min-width:0}.kb-article-title{display:block;font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kb-article-meta{display:flex;align-items:center;gap:8px;font-size:.78rem;color:#6b7280;margin-top:2px}.kb-files-badge{background:#f3f4f6;padding:1px 6px;border-radius:8px;font-size:.72rem}.kb-article-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.kb-article-item:hover .kb-article-actions{opacity:1}.btn-icon{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px 6px;border-radius:4px;color:#6b7280;transition:.15s;line-height:1}.btn-icon:hover{background:#e5e7eb;color:#374151}.btn-icon-danger:hover{background:#fee2e2;color:#dc2626}.kb-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;border-radius:10px;padding:60px 20px;box-shadow:0 1px 4px #0000000f;color:#9ca3af;text-align:center;min-height:400px}.kb-placeholder-icon{font-size:3rem;margin-bottom:12px}.kb-article-view{background:#fff;border-radius:10px;padding:28px 32px;box-shadow:0 1px 4px #0000000f}.kb-article-view-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.kb-article-view-header h2{font-size:1.4rem;font-weight:700;color:#1a1a2e;margin:0}.kb-article-view-actions{display:flex;gap:8px;flex-shrink:0}.kb-article-view-meta{display:flex;gap:16px;font-size:.82rem;color:#6b7280;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.kb-article-body{font-size:.94rem;line-height:1.7;color:#374151}.kb-article-body h2{font-size:1.25rem;font-weight:700;margin:20px 0 10px;color:#1a1a2e}.kb-article-body h3{font-size:1.1rem;font-weight:600;margin:16px 0 8px;color:#1a1a2e}.kb-article-body p{margin-bottom:10px}.kb-article-body ul,.kb-article-body ol{padding-left:24px;margin-bottom:10px}.kb-article-body li{margin-bottom:4px}.kb-article-body img{max-width:100%;height:auto;border-radius:8px;margin:10px 0;box-shadow:0 2px 8px #0000001a}.kb-article-body a{color:#4f46e5;text-decoration:underline}.kb-article-body a:hover{color:#4338ca}.kb-editor-wrapper{background:#fff;border-radius:10px;padding:24px 28px;box-shadow:0 1px 4px #0000000f}.kb-toolbar{display:flex;align-items:center;gap:2px;padding:8px 10px;background:#f8fafc;border:1px solid #e5e7eb;border-bottom:none;border-radius:8px 8px 0 0;flex-wrap:wrap}.kb-toolbar-btn{background:none;border:1px solid transparent;cursor:pointer;padding:5px 10px;border-radius:5px;font-size:.85rem;color:#374151;transition:.15s;line-height:1.2}.kb-toolbar-btn:hover{background:#e5e7eb;border-color:#d1d5db}.kb-toolbar-sep{width:1px;height:22px;background:#d1d5db;margin:0 4px}.kb-editor{min-height:300px;max-height:600px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:0 0 8px 8px;padding:16px 20px;font-size:.94rem;line-height:1.7;color:#374151;outline:none}.kb-editor:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.kb-editor h2{font-size:1.25rem;font-weight:700;margin:14px 0 8px}.kb-editor h3{font-size:1.1rem;font-weight:600;margin:10px 0 6px}.kb-editor img{max-width:100%;height:auto;border-radius:6px;margin:8px 0}.kb-editor ul,.kb-editor ol{padding-left:24px}.kb-files-section{margin-top:20px}.kb-files-section h4{font-size:.95rem;font-weight:600;color:#374151;margin-bottom:10px}.kb-files-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.kb-files-header h4{margin:0}.kb-files-list{display:flex;flex-direction:column;gap:6px}.kb-file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:7px;transition:background .15s}.kb-file-item:hover{background:#f1f5f9}.kb-file-link{text-decoration:none;color:inherit;cursor:pointer}.kb-file-link:hover{background:#e0e7ff;border-color:#c7d2fe}.kb-file-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.kb-file-name{font-size:.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kb-file-size{font-size:.78rem;color:#6b7280;flex-shrink:0}.kb-new-files{border:2px dashed #c7d2fe;border-radius:8px;padding:10px;background:#f5f3ff}.kb-new-files-label{font-size:.82rem;font-weight:600;color:#4f46e5;margin-bottom:6px}.kb-empty{text-align:center;padding:16px;color:#9ca3af;font-size:.88rem}.bulk-assign-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 0;margin-bottom:12px;gap:12px;flex-wrap:wrap}.bulk-assign-info{display:flex;align-items:center;gap:10px}.race-checkbox{width:17px;height:17px;cursor:pointer;accent-color:#4f46e5}
