.sidebar-container{width:280px;height:100vh;background-color:#0f172a;color:#f8fafc;display:flex;flex-direction:column;border-right:1px solid #1e293b;flex-shrink:0;padding:24px 16px;box-shadow:4px 0 20px #00000014}.sidebar-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding:0 8px}.brand-logo{width:36px;height:36px;color:#6366f1}.brand-text h2{font-size:1.1rem;font-weight:700;letter-spacing:-.025em;line-height:1.2}.brand-text span{font-size:.75rem;color:#64748b;font-weight:500}.sidebar-user{display:flex;align-items:center;gap:12px;padding:12px;background-color:#1e293b;border-radius:var(--border-radius-md);margin-bottom:16px}.user-avatar{width:32px;height:32px;color:#94a3b8}.user-info h4{font-size:.875rem;font-weight:600;color:#f8fafc}.user-info span{font-size:.7rem;color:#94a3b8;display:block}.sidebar-month-selector{padding:12px;background-color:#1e293b;border:1px solid #334155;border-radius:var(--border-radius-md);margin-bottom:20px}.sidebar-month-selector label{display:block;font-size:.7rem;color:#94a3b8;font-weight:600;text-transform:uppercase;margin-bottom:6px}.sidebar-month-selector input[type=month]{width:100%;padding:6px 10px;background-color:#0f172a;border:1px solid #475569;color:#f8fafc;border-radius:var(--border-radius-sm);font-size:.85rem;font-weight:500;outline:none;cursor:pointer;box-sizing:border-box}.sidebar-month-selector input[type=month]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.sidebar-nav{flex-1:1 1 auto;overflow-y:auto}.sidebar-nav ul{list-style:none}.sidebar-nav li{margin-bottom:4px}.nav-link{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;color:#94a3b8;font-size:.875rem;font-weight:500;border-radius:var(--border-radius-sm);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.nav-link:hover{background-color:#1e293b;color:#f8fafc}.nav-link.active{background-color:#4f46e5;color:#fff}.nav-icon{width:18px;height:18px;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid #1e293b}.logout-btn{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;color:#ef4444;font-size:.875rem;font-weight:500;border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.logout-btn:hover{background-color:#fef2f2;color:#ef4444}.dashboard-container{display:flex;flex-direction:column;gap:24px}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:16px;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.dashboard-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:16px}.dashboard-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.dashboard-header p{font-size:.875rem;color:var(--text-secondary);margin-top:4px}.month-badge{display:flex;align-items:center;gap:8px;background-color:var(--bg-tertiary);padding:8px 16px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;color:var(--color-primary);border:1px solid var(--border-color)}.badge-icon{width:16px;height:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.stats-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.stats-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stats-icon-bg{width:48px;height:48px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center}.color-indigo{background-color:#e0e7ff;color:#4f46e5}.color-emerald{background-color:#d1fae5;color:#10b981}.color-warning{background-color:#fef3c7;color:#d97706}.color-danger{background-color:#fee2e2;color:#ef4444}.stats-icon{width:24px;height:24px}.stats-content span{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.stats-content h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:4px 0}.success-text{font-size:.75rem;color:var(--color-success);font-weight:600}.muted-text{font-size:.75rem;color:var(--text-muted)}.dashboard-content-split{display:grid;grid-template-columns:1.8fr 1.2fr;gap:24px}@media(max-width:1024px){.dashboard-content-split{grid-template-columns:1fr}}.compliance-panel,.quick-action-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px}.panel-header{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-color);padding-bottom:12px}.panel-header-icon{width:22px;height:22px}.text-danger{color:var(--color-danger)}.panel-header h2{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.issues-list{display:flex;flex-direction:column;gap:12px}.issue-item{padding:14px 16px;background-color:var(--bg-primary);border-radius:var(--border-radius-md);border:1px solid var(--border-color);border-left-width:4px}.border-danger{border-left-color:var(--color-danger)}.border-warning{border-left-color:var(--color-warning)}.issue-title{display:flex;align-items:center;gap:10px;margin-bottom:6px}.badge{font-size:.65rem;font-weight:700;text-transform:uppercase;padding:3px 6px;border-radius:4px;color:#fff}.bg-danger{background-color:var(--color-danger)}.bg-warning{background-color:var(--color-warning)}.issue-title h4{font-size:.875rem;font-weight:600;color:var(--text-primary)}.issue-item p{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.quick-tips{display:flex;flex-direction:column;gap:12px}.tip-card{padding:12px 14px;background-color:var(--bg-tertiary);border-radius:var(--border-radius-md);border:1px solid var(--border-color)}.tip-card h5{font-size:.875rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.tip-card p{font-size:.775rem;color:var(--text-secondary);line-height:1.4}.emp-master-container{display:flex;flex-direction:column;gap:20px;height:100%}.emp-action-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.search-box{position:relative;flex:1;max-width:480px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted)}.search-box input{width:100%;padding:10px 16px 10px 40px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);outline:none;font-size:.875rem;color:var(--text-primary);background-color:var(--bg-primary);transition:all var(--transition-fast)}.search-box input:focus{border-color:var(--color-primary);background-color:var(--bg-secondary);box-shadow:0 0 0 3px #4f46e51a}.add-emp-btn{display:flex;align-items:center;gap:8px;background-color:var(--color-primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.add-emp-btn:hover{background-color:var(--color-primary-hover)}.btn-icon{width:18px;height:18px}.emp-grid-split{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}@media(max-width:900px){.emp-grid-split{grid-template-columns:1fr}}.emp-list-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 180px);overflow-y:auto}.panel-header-simple h3{font-size:.95rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.025em}.emp-list{display:flex;flex-direction:column;gap:8px}.emp-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:var(--border-radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.emp-item:hover{background-color:var(--bg-tertiary);border-color:var(--border-color)}.emp-item.selected{background-color:#eeebff;border-color:#c7d2fe}.emp-item-left{display:flex;align-items:center;gap:12px}.emp-avatar-text{width:38px;height:38px;border-radius:50%;background-color:#e0e7ff;color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700}.emp-item.selected .emp-avatar-text{background-color:var(--color-primary);color:#fff}.emp-item h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.emp-item span{font-size:.75rem;color:var(--text-secondary)}.emp-dept-badge{font-size:.7rem;font-weight:600;color:var(--color-primary);background-color:#eeebff;padding:3px 8px;border-radius:20px}.emp-detail-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px;box-shadow:var(--shadow-sm);height:calc(100vh - 180px);overflow-y:auto}.emp-detail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;color:var(--text-muted);gap:16px;text-align:center}.placeholder-icon{width:48px;height:48px;stroke-width:1.5px}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border-color);padding-bottom:16px;margin-bottom:20px}.detail-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.detail-header p{font-size:.875rem;color:var(--text-secondary);margin-top:4px}.edit-btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);padding:8px 16px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.edit-btn-outline:hover{background-color:var(--bg-primary);border-color:var(--text-primary)}.detail-sections{display:flex;flex-direction:column;gap:24px}.detail-section{display:flex;flex-direction:column;gap:12px}.section-title{display:flex;align-items:center;gap:8px;color:var(--color-primary);border-bottom:1px solid var(--bg-tertiary);padding-bottom:6px}.section-title-flex{display:flex;justify-content:space-between;align-items:center}.section-icon{width:20px;height:20px}.section-title h4{font-size:.95rem;font-weight:700;color:var(--text-primary)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.info-grid div,.info-grid-simple div{font-size:.875rem;line-height:1.5}.info-grid label,.info-grid-simple label{color:var(--text-secondary);display:block;font-size:.775rem;margin-bottom:2px}.info-grid span,.info-grid-simple span{font-weight:500;color:var(--text-primary)}.info-grid-simple{display:flex;gap:32px}.add-dep-link{background:transparent;border:none;color:var(--color-primary);font-size:.825rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px}.link-icon{width:14px;height:14px}.dep-table{width:100%;border-collapse:collapse;margin-top:8px}.dep-table th,.dep-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-color);font-size:.825rem}.dep-table th{background-color:var(--bg-primary);color:var(--text-secondary);font-weight:600}.dep-table td{color:var(--text-primary)}.delete-btn-table{background:transparent;border:none;color:var(--color-danger);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.delete-btn-table:hover{background-color:var(--color-danger-bg)}.table-btn-icon{width:16px;height:16px}.no-data-text{font-size:.825rem;color:var(--text-muted);font-style:italic}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999}.modal-content{background-color:var(--bg-secondary);border-radius:var(--border-radius-lg);width:100%;max-width:640px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.add-employee-modal,.edit-employee-modal{width:95%;max-width:1200px}@media(min-width:768px){.add-employee-modal,.edit-employee-modal{width:80%}}.add-employee-modal .form-grid,.edit-employee-modal .form-grid{grid-template-columns:repeat(3,1fr)}.form-group-span-2{grid-column:span 2;display:flex;flex-direction:column;gap:6px}.form-section-header{grid-column:span 2;border-bottom:1px solid var(--border-color);padding-bottom:6px;margin-bottom:8px;margin-top:12px}.form-section-header:first-of-type{margin-top:0}.add-employee-modal .form-section-header,.edit-employee-modal .form-section-header{grid-column:span 3}.form-section-header h4{margin:0;font-size:.9rem;color:var(--color-primary);font-weight:600}.add-employee-modal .form-group-full,.edit-employee-modal .form-group-full{grid-column:span 3}@media(max-width:992px){.add-employee-modal .form-grid,.edit-employee-modal .form-grid{grid-template-columns:repeat(2,1fr)}.add-employee-modal .form-section-header,.edit-employee-modal .form-section-header,.add-employee-modal .form-group-full,.edit-employee-modal .form-group-full{grid-column:span 2}}@media(max-width:600px){.add-employee-modal .form-grid,.edit-employee-modal .form-grid{grid-template-columns:1fr}.add-employee-modal .form-section-header,.edit-employee-modal .form-section-header,.form-section-header,.add-employee-modal .form-group-full,.edit-employee-modal .form-group-full,.form-group-full,.form-group-span-2{grid-column:span 1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-color);background-color:var(--bg-primary)}.modal-header h3{font-size:1.1rem;font-weight:700}.close-modal{background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.modal-form{padding:24px;display:flex;flex-direction:column;gap:20px;max-height:75vh;overflow-y:auto}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.form-group label{font-size:.775rem;font-weight:600;color:var(--text-secondary)}.form-group input,.form-group select{padding:10px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-size:.875rem;outline:none;background-color:var(--bg-primary)}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);background-color:var(--bg-secondary)}.submit-btn{background-color:var(--color-primary);color:#fff;border:none;padding:12px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.submit-btn:hover{background-color:var(--color-primary-hover)}.emp-avatar-img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:1px solid var(--border-color)}.detail-header-left{display:flex;align-items:center;gap:16px}.emp-detail-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--color-primary);box-shadow:var(--shadow-sm)}.emp-detail-avatar-text{width:72px;height:72px;border-radius:50%;background-color:#e0e7ff;color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;border:2px solid var(--color-primary)}.status-badge{display:inline-block;font-size:.725rem;font-weight:600;padding:2px 8px;border-radius:12px;margin-top:4px}.status-badge.active{background-color:var(--color-success-bg);color:var(--color-success)}.status-badge.inactive{background-color:var(--color-danger-bg);color:var(--color-danger)}.modal-content.edit-modal-content{max-width:680px}.modal-tabs{display:flex;background-color:var(--bg-tertiary);padding:4px;margin:12px 24px 0;border-radius:var(--border-radius-md);gap:4px}.tab-btn{flex:1;background:transparent;border:none;padding:8px 12px;font-size:.8rem;font-weight:600;color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.tab-btn:hover{background-color:#ffffff80;color:var(--text-primary)}.tab-btn.active{background-color:var(--bg-secondary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.form-group-full{grid-column:span 2;display:flex;flex-direction:column;gap:6px}.form-group-full label{font-size:.775rem;font-weight:600;color:var(--text-secondary)}.form-group-full input,.form-group-full select{padding:10px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-size:.875rem;outline:none;background-color:var(--bg-primary);width:100%;transition:all var(--transition-fast)}.form-group-full input:focus,.form-group-full select:focus{border-color:var(--color-primary);background-color:var(--bg-secondary)}.avatar-upload-container{display:flex;align-items:center;gap:16px;background-color:var(--bg-primary);padding:12px;border-radius:var(--border-radius-md);border:1px dashed var(--border-color)}.avatar-preview-img{width:60px;height:60px;border-radius:50%;object-fit:cover;border:1px solid var(--border-color)}.avatar-preview-placeholder{width:60px;height:60px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.upload-placeholder-icon{width:24px;height:24px}.avatar-upload-controls{display:flex;flex-direction:column;gap:8px;flex:1}.file-upload-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:6px 12px;border-radius:var(--border-radius-sm);font-size:.775rem;font-weight:600;cursor:pointer;align-self:flex-start;transition:all var(--transition-fast)}.file-upload-btn:hover{background-color:var(--bg-tertiary);border-color:var(--text-secondary)}.avatar-url-input{padding:8px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.775rem;outline:none;background-color:var(--bg-secondary)}.avatar-url-input:focus{border-color:var(--color-primary)}.avatar-preview-wrapper{display:flex;flex-direction:column;align-items:center;gap:6px}.clear-avatar-btn{background:transparent;border:1px solid var(--color-danger);color:var(--color-danger);padding:2px 8px;border-radius:var(--border-radius-sm);font-size:.7rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.clear-avatar-btn:hover{background-color:var(--color-danger-bg)}.avatar-upload-status{font-size:.775rem;color:var(--color-success);font-weight:500}.edm-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background-color:var(--bg-primary);border:2px dashed var(--border-color);border-radius:var(--border-radius-lg);text-align:center;transition:all var(--transition-fast) ease-in-out;margin-top:10px}.edm-dropzone.dragging{border-color:var(--color-primary);background-color:#6366f10d;transform:scale(1.02)}.upload-dropzone-icon{width:32px;height:32px;color:var(--color-primary);margin-bottom:8px}.edm-dropzone p{font-size:.85rem;font-weight:600;color:var(--text-primary);margin:0 0 4px}.edm-file-label{color:var(--color-primary);cursor:pointer;text-decoration:underline}.edm-dropzone span{font-size:.725rem;color:var(--text-muted)}.preview-modal-content{max-width:800px;max-height:90vh;display:flex;flex-direction:column}.preview-media-container{display:flex;justify-content:center;align-items:center;background-color:#0f172a;padding:20px;overflow:auto;min-height:300px}.contract-paper-preview{box-shadow:var(--shadow-md);padding:40px;background:#fff;color:#000;font-family:Times New Roman,Times,serif;line-height:1.6;font-size:14px;overflow-y:auto;max-height:60vh;border:1px solid var(--border-color)}.contract-preview-modal-content{max-width:1200px;width:95vw;max-height:95vh;display:flex;flex-direction:column}.contract-split-layout{display:flex;flex-direction:row;gap:20px;padding:20px;background-color:var(--bg-tertiary);overflow-y:auto;max-height:calc(95vh - 70px)}.contract-ai-panel{flex:1;display:flex;flex-direction:column;gap:16px;padding:20px;background-color:var(--bg-primary);border-radius:8px;border:1px solid var(--border-color);max-height:80vh;overflow-y:auto}.contract-paper-view-panel{flex:1.3;display:flex;flex-direction:column;gap:12px;max-height:80vh;overflow-y:auto}.contract-ai-panel .ai-form-group{display:flex;flex-direction:column;gap:6px}.contract-ai-panel label{font-weight:600;font-size:13px;color:var(--text-secondary)}.contract-ai-panel textarea{width:100%;padding:10px;border-radius:6px;border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);font-family:inherit;font-size:13px;resize:vertical}.contract-ai-panel textarea:focus{outline:none;border-color:var(--color-primary)}.ai-generate-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;padding:10px 16px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.ai-generate-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.ai-generate-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.contract-paper-preview{max-height:none;height:auto}@media(max-width:1024px){.contract-split-layout{flex-direction:column;max-height:none}.contract-ai-panel,.contract-paper-view-panel{max-height:none;flex:none}}.btn-word-export{background-color:#185abd;color:#fff;border:none;padding:12px 18px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast);display:inline-flex;align-items:center;gap:6px}.btn-word-export:hover{background-color:#124993}.disabled-input{background-color:var(--bg-tertiary)!important;border-style:dashed!important;color:var(--text-muted)!important;cursor:not-allowed}.auto-id-hint{font-style:italic}.field-note{font-size:.72rem;color:var(--text-muted);line-height:1.3;margin-top:2px}.attendance-module-container{display:flex;flex-direction:column;gap:20px;height:100%}.attendance-action-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-size:.875rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.filter-group select{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-size:.875rem;outline:none;background-color:var(--bg-primary);min-width:240px}.icon-small{width:16px;height:16px}.summary-boxes{display:flex;gap:12px}.summary-box{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:8px 16px;text-align:center;display:flex;flex-direction:column;gap:2px}.summary-box span{font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--text-secondary)}.summary-box strong{font-size:1rem;font-weight:700;color:var(--text-primary)}.save-attendance-btn{display:flex;align-items:center;gap:8px;background-color:var(--color-primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.save-attendance-btn:hover{background-color:var(--color-primary-hover)}.save-attendance-btn:disabled{background-color:var(--text-muted);cursor:not-allowed}.alert-banner-danger{display:flex;align-items:center;gap:10px;background-color:var(--color-danger-bg);border:1px solid #fca5a5;color:var(--color-danger);padding:12px 16px;border-radius:var(--border-radius-md);font-size:.825rem;font-weight:500}.alert-icon{width:18px;height:18px;flex-shrink:0}.attendance-grid-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:20px;height:calc(100vh - 280px);overflow:hidden;display:flex;flex-direction:column}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:16px}.calendar-grid-wrapper{display:flex;flex-direction:column;gap:10px;height:100%;overflow:hidden}.calendar-weekdays-header{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;text-align:center;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:10px 0;font-size:.825rem;font-weight:700;color:var(--text-secondary)}.calendar-cells-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;overflow-y:auto;flex:1;padding-right:4px}.calendar-cell{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:8px 10px;min-height:110px;display:flex;flex-direction:column;transition:all var(--transition-fast) ease-in-out}.cell-padding{opacity:.4;background-color:var(--bg-tertiary)}.cell-active{cursor:pointer;border-top-width:4px}.cell-active:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-hover)}.cell-weekend{background-color:var(--bg-tertiary)}.cell-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:4px;margin-bottom:6px}.day-number{font-size:.95rem;font-weight:700;color:var(--text-primary)}.day-check-times{font-size:.725rem;color:var(--text-secondary);font-weight:500}.cell-body{display:flex;flex-direction:column;gap:6px;flex-grow:1}.border-status-worked{border-top-color:#10b981!important}.tag-worked{background-color:#d1fae5;color:#065f46}.border-status-leave-paid{border-top-color:#3b82f6!important}.tag-leave-paid{background-color:#dbeafe;color:#1e40af}.border-status-holiday{border-top-color:#8b5cf6!important}.tag-holiday{background-color:#ede9fe;color:#5b21b6}.border-status-sick{border-top-color:#ef4444!important}.tag-sick{background-color:#fee2e2;color:#991b1b}.border-status-leave-unpaid{border-top-color:#6b7280!important}.tag-leave-unpaid{background-color:#f3f4f6;color:#374151}.status-tag{font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px;align-self:flex-start}.cell-metric{display:flex;align-items:center;gap:4px;font-size:.725rem;color:var(--text-secondary)}.icon-metric{width:12px;height:12px;color:var(--text-muted)}.metric-ot{background-color:#6366f11a;color:#6366f1;padding:2px 6px;border-radius:4px;align-self:flex-start;font-size:.7rem;font-weight:600}.cell-late-tag{background-color:#fef2f2;color:#ef4444;padding:2px 6px;border-radius:4px;align-self:flex-start;font-size:.7rem;font-weight:600;border:1px solid #fee2e2}.attendance-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0f172ab3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn var(--transition-fast) ease-out}.attendance-modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:520px;max-width:95%;display:flex;flex-direction:column;animation:slideIn var(--transition-fast) ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.close-modal-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.close-modal-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:20px;display:flex;flex-direction:column;gap:16px;max-height:70vh;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.775rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-group select,.form-group input[type=text],.form-group input[type=time],.form-group input[type=number],.form-group input[type=date]{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;outline:none;transition:border var(--transition-fast);width:100%;box-sizing:border-box}.form-group select:focus,.form-group input:focus{border-color:var(--color-primary)}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.btn-cancel{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);padding:10px 20px;border-radius:var(--border-radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.btn-cancel:hover{background-color:var(--border-color);color:var(--text-primary)}.btn-confirm{background-color:var(--color-primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:background var(--transition-fast)}.btn-confirm:hover{background-color:var(--color-primary-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.attendance-tabs-container{display:flex;border-bottom:2px solid var(--border-color);gap:20px;margin-bottom:12px}.attendance-tab-link{background:none;border:none;padding:10px 4px;font-size:.9rem;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.attendance-tab-link:hover{color:var(--color-primary)}.attendance-tab-link.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.requests-tab-grid{display:grid;grid-template-columns:320px 1fr;gap:20px;width:100%;height:100%;overflow:hidden}.requests-form-card{background-color:var(--bg-secondary);padding:16px 20px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);overflow:hidden;height:100%;display:flex;flex-direction:column}.segmented-control{display:flex;background-color:var(--bg-tertiary);padding:4px;border-radius:var(--border-radius-md);margin-bottom:16px;gap:4px}.segmented-btn{flex:1;background:none;border:none;padding:8px;font-size:.775rem;font-weight:600;color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.segmented-btn.active{background-color:var(--bg-secondary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:9999px;font-size:.725rem;font-weight:700;text-transform:uppercase}.status-badge.pending{background-color:#f59e0b1a;color:#d97706}.status-badge.approved{background-color:#10b9811a;color:#059669}.status-badge.rejected{background-color:#ef44441a;color:#dc2626}.action-btn-group{display:flex;gap:8px;justify-content:center}.action-btn-approve,.action-btn-reject{border:none;padding:6px 12px;border-radius:var(--border-radius-md);font-size:.75rem;font-weight:600;cursor:pointer;color:#fff;transition:opacity var(--transition-fast)}.action-btn-approve:hover,.action-btn-reject:hover{opacity:.9}.action-btn-approve{background-color:var(--color-success)}.action-btn-reject{background-color:var(--color-danger)}.sub-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.sub-header-row h3{font-size:.95rem;font-weight:700;margin:0;color:var(--text-primary)}.list-filter-tabs{display:flex;gap:8px}.list-filter-btn{background:none;border:1px solid var(--border-color);padding:4px 10px;font-size:.725rem;font-weight:600;color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.list-filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.list-filter-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.kpi-module-container{display:flex;flex-direction:column;gap:20px;height:100%}.kpi-action-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap}.kpi-summary-badge{display:flex;align-items:center;gap:8px;background-color:#eeebff;padding:8px 16px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;color:var(--color-primary);border:1px solid #c7d2fe}.save-kpi-btn{display:flex;align-items:center;gap:8px;background-color:var(--color-primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.save-kpi-btn:hover{background-color:var(--color-primary-hover)}.save-kpi-btn:disabled{background-color:var(--text-muted);cursor:not-allowed}.kpi-main-split{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start}@media(max-width:1024px){.kpi-main-split{grid-template-columns:1fr}}.kpi-scorecard-panel,.kpi-veto-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.scorecard-sections{display:flex;flex-direction:column;gap:20px;margin-top:16px}.scorecard-section{background-color:var(--bg-primary);padding:16px;border-radius:var(--border-radius-md);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px}.scorecard-section h5{font-size:.8rem;font-weight:700;color:var(--text-primary);letter-spacing:.025em;border-bottom:1px solid var(--border-color);padding-bottom:6px}.score-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.score-input-group{display:flex;flex-direction:column;gap:6px}.score-input-group label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.score-input-group input{padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.8rem;width:100%;outline:none;background-color:#fff}.score-input-group input:focus{border-color:var(--color-primary)}.score-input-group input:disabled{background-color:var(--bg-tertiary);color:var(--text-secondary);border-color:transparent;cursor:not-allowed}.scorecard-summary-row{display:flex;justify-content:space-between;margin-top:24px;border-top:2px solid var(--border-color);padding-top:16px}.scorecard-summary-row div{font-size:.875rem;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.scorecard-summary-row strong{font-size:1.25rem;font-weight:700}.text-primary{color:var(--color-primary)}.kpi-veto-panel{display:flex;flex-direction:column;gap:16px}.helper-text{font-size:.775rem;color:var(--text-secondary);line-height:1.4}.veto-checkboxes{display:flex;flex-direction:column;gap:12px}.checkbox-label{display:flex;align-items:flex-start;gap:12px;padding:12px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast)}.checkbox-label:hover{background-color:var(--bg-tertiary);border-color:var(--text-secondary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin-top:2px;cursor:pointer}.checkbox-label div{display:flex;flex-direction:column;gap:2px}.checkbox-label strong{font-size:.825rem;font-weight:700;color:var(--text-primary)}.checkbox-label span{font-size:.75rem;color:var(--text-secondary);line-height:1.3}.checkbox-label input:disabled+div{opacity:.8;cursor:not-allowed}.veto-status-box{margin-top:16px}.veto-status{display:flex;align-items:flex-start;gap:12px;padding:16px;border-radius:var(--border-radius-md);border:1px solid}.veto-status.success{background-color:var(--color-success-bg);border-color:#a7f3d0;color:var(--color-success)}.veto-status.danger{background-color:var(--color-danger-bg);border-color:#fca5a5;color:var(--color-danger)}.status-icon{width:24px;height:24px;flex-shrink:0}.veto-status h4{font-size:.875rem;font-weight:700;margin-bottom:2px}.veto-status p{font-size:.775rem;color:var(--text-secondary);line-height:1.4}.payroll-module-container{display:flex;flex-direction:column;gap:20px;height:100%}.payroll-action-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap}.payroll-title{display:flex;align-items:center;gap:12px}.payroll-title h3{font-size:1.2rem;font-weight:700}.lock-tag{display:flex;align-items:center;gap:4px;background-color:var(--color-danger-bg);border:1px solid #fca5a5;color:var(--color-danger);padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.lock-icon{width:14px;height:14px}.toolbar-buttons{display:flex;gap:10px;flex-wrap:wrap}.calc-btn,.calc-btn-large{display:flex;align-items:center;gap:8px;background-color:var(--color-primary);color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.calc-btn:hover{background-color:var(--color-primary-hover)}.approve-pay-btn{display:flex;align-items:center;gap:8px;background-color:var(--color-success);color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius-md);font-size:.85rem;font-weight:600;cursor:pointer}.approve-pay-btn:hover{background-color:#059669}.export-excel-btn{display:flex;align-items:center;gap:8px;background-color:#10b981;color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius-md);font-size:.85rem;font-weight:600;cursor:pointer}.formula-config-btn{display:flex;align-items:center;gap:8px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:8px 16px;border-radius:var(--border-radius-md);font-size:.85rem;font-weight:600;cursor:pointer}.formula-config-btn:hover{background-color:var(--border-color)}.payroll-grid-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:16px;height:calc(100vh - 280px);overflow:hidden;display:flex;flex-direction:column}.payroll-table-wrapper{overflow-x:auto;max-height:calc(100vh - 340px)}.payroll-table{width:100%;border-collapse:collapse;text-align:left}.payroll-table th,.payroll-table td{padding:10px 12px;border-bottom:1px solid var(--border-color);font-size:.8rem;white-space:nowrap}.payroll-table th{background-color:var(--bg-primary);color:var(--text-secondary);font-weight:700;position:sticky;top:0;z-index:10}.view-payslip-link{background:transparent;border:1px solid var(--border-color);padding:4px 8px;border-radius:var(--border-radius-sm);font-size:.775rem;cursor:pointer;display:flex;align-items:center;gap:4px}.view-payslip-link:hover{background-color:var(--bg-tertiary);border-color:var(--text-secondary)}.table-link-icon{width:14px;height:14px}.no-payroll-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:16px;color:var(--text-secondary)}.no-data-icon{width:48px;height:48px;stroke-width:1.5px;color:var(--text-muted)}.calc-btn-large{padding:12px 24px;font-size:.9rem;margin-top:8px}.payslip-modal-content{max-width:800px;width:100%}.header-actions{display:flex;align-items:center;gap:12px}.print-btn-outline{display:flex;align-items:center;gap:6px;background-color:var(--bg-secondary);border:1px solid var(--border-color);padding:6px 12px;border-radius:var(--border-radius-md);font-size:.8rem;font-weight:600;cursor:pointer}.print-btn-outline:hover{background-color:var(--bg-tertiary);border-color:var(--text-primary)}.printable-payslip{padding:32px;background-color:#fff;color:#000;font-family:Times New Roman,Times,serif}.payslip-header{text-align:center;margin-bottom:24px}.payslip-header h2{font-size:1.4rem;font-weight:700;letter-spacing:.05em;margin-bottom:4px}.company-title{font-size:.85rem;font-weight:600;margin-top:4px}.company-info-payslip{font-size:.725rem;color:var(--text-secondary);margin-top:2px}.payslip-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px;font-size:.9rem;border-bottom:1px solid #000;padding-bottom:16px}.payslip-meta-grid label{font-weight:700}.payslip-breakdown-table{width:100%;border-collapse:collapse;margin-bottom:24px}.payslip-breakdown-table th,.payslip-breakdown-table td{border:1px solid #000;padding:8px 10px;font-size:.85rem;text-align:left}.payslip-breakdown-table th{background-color:#f2f2f2;font-weight:700}.payslip-totals-row td{background-color:#f9f9f9}.payslip-net-row{display:flex;justify-content:space-between;align-items:center;border:2px solid #000;padding:12px 16px;margin-bottom:32px}.payslip-net-row h3{font-size:1rem;font-weight:700}.payslip-signature-row{display:grid;grid-template-columns:repeat(3,1fr);text-align:center;font-size:.875rem;margin-top:40px}.payslip-signature-row p{font-weight:700;margin-bottom:60px}.payslip-signature-row span{font-size:.775rem;font-style:italic}.formula-modal-content{max-width:900px;width:100%}.formula-panel-body{padding:24px;display:flex;flex-direction:column;gap:16px;max-height:calc(100vh - 120px);overflow-y:auto}.alert-banner-warning{background-color:var(--color-warning-bg);border:1px solid #fde047;color:var(--color-warning);padding:12px 16px;border-radius:var(--border-radius-md);font-size:.8rem;line-height:1.4}.formula-table{width:100%;border-collapse:collapse}.formula-table th,.formula-table td{padding:8px 12px;border:1px solid var(--border-color);font-size:.825rem;text-align:left}.formula-table th{background-color:var(--bg-primary);font-weight:600}@media print{body *{visibility:hidden}.print-overlay,.printable-payslip,.printable-payslip *{visibility:visible}.print-overlay{position:absolute;left:0;top:0;width:100%;background-color:#fff;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.no-print{display:none!important}.payslip-modal-content{border:none;box-shadow:none}.printable-payslip{padding:0;margin:0}}.formula-input-text,.formula-input-num,.formula-select{width:100%;padding:6px 10px;font-size:.8rem;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background-color:var(--bg-tertiary);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.formula-input-text:focus,.formula-input-num:focus,.formula-select:focus{border-color:var(--color-primary)}.formula-input-text.code-field:disabled{background-color:var(--bg-secondary);border-style:dashed;cursor:not-allowed;color:var(--text-muted)}.add-allowance-btn-mini{display:flex;align-items:center;gap:4px;padding:6px 12px;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius-sm);font-size:.775rem;font-weight:700;cursor:pointer;transition:all var(--transition-normal)}.add-allowance-btn-mini:hover{background-color:#4f46e5;transform:translateY(-1px)}.remove-allowance-row-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;transition:color var(--transition-fast)}.remove-allowance-row-btn:hover{color:var(--color-danger)}.system-tag-mini{font-size:.7rem;font-weight:600;color:var(--text-muted);background-color:var(--bg-tertiary);padding:2px 6px;border-radius:var(--border-radius-sm);border:1px solid var(--border-color)}.formula-modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;border-top:1px solid var(--border-color);padding-top:16px}.btn-cancel-settings,.btn-save-settings{padding:8px 16px;font-size:.8rem;font-weight:600;border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-cancel-settings{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-cancel-settings:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-save-settings{background-color:var(--color-primary);border:none;color:#fff}.btn-save-settings:hover{background-color:#4f46e5}.config-section-header h4{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.var-pill{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);font-size:.7rem;padding:3px 8px;border-radius:99px;cursor:pointer;transition:all var(--transition-fast);font-weight:500}.var-pill:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.preset-select{transition:all var(--transition-fast);outline:none}.preset-select:hover,.preset-select:focus{border-color:var(--color-primary)!important}.offboarding-module-container{display:flex;flex-direction:column;gap:20px;height:100%}.offboarding-action-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap}.confirm-offboard-btn{display:flex;align-items:center;gap:8px;background-color:var(--color-danger);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius-md);font-size:.875rem;font-weight:600;cursor:pointer}.confirm-offboard-btn:hover{background-color:#e11d48}.offboarding-main-split{display:grid;grid-template-columns:1.2fr 1.8fr;gap:20px;align-items:start}@media(max-width:1024px){.offboarding-main-split{grid-template-columns:1fr}}.offboarding-panel-left,.offboarding-panel-right{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.calculator-form{display:flex;flex-direction:column;gap:16px;margin-top:16px}.helper-label{font-size:.725rem;color:var(--text-muted);margin-top:2px}.offboarding-results{display:flex;flex-direction:column;gap:14px;margin-top:16px}.result-row{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--bg-primary);padding-bottom:8px}.result-row strong{color:var(--text-primary)}.warning-row{background-color:var(--color-warning-bg);padding:8px 12px;border-radius:var(--border-radius-sm);border-left:3px solid var(--color-warning)}.warning-row strong{color:#d97706}.highlight-row{background-color:#eeebff;padding:8px 12px;border-radius:var(--border-radius-sm);border-left:3px solid var(--color-primary)}.highlight-row strong{color:var(--color-primary)}.divider{border:0;height:1px;background-color:var(--border-color);margin:10px 0}.result-row-amount{display:flex;justify-content:space-between;font-size:.9rem;font-weight:500;color:var(--text-primary)}.total-payout-box{margin-top:16px;background-color:var(--color-success-bg);border:1px solid #a7f3d0;padding:16px;border-radius:var(--border-radius-md);text-align:center;display:flex;flex-direction:column;gap:4px}.total-payout-box span{font-size:.75rem;font-weight:700;color:var(--color-success);letter-spacing:.05em}.total-payout-box h2{font-size:1.6rem;font-weight:800;color:var(--color-success)}.legal-reference-note{margin-top:24px;padding:16px;background-color:var(--bg-primary);border-radius:var(--border-radius-md);border:1px solid var(--border-color)}.legal-reference-note h5{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.legal-reference-note p{font-size:.775rem;color:var(--text-secondary);line-height:1.4;margin-bottom:8px}.legal-reference-note p:last-child{margin-bottom:0}.legal-module-container{display:flex;flex-direction:column;gap:24px;height:100%;padding-bottom:24px}.legal-header-card{background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(99,102,241,.05) 100%);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px 24px 0;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:20px}.legal-title{display:flex;align-items:center;gap:16px}.legal-title h3{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.02em}.legal-title p{font-size:.85rem;color:var(--text-secondary)}.brand-logo-small{width:32px;height:32px;color:var(--color-primary)}.legal-tabs-nav{display:flex;gap:8px}.tab-nav-btn{background:none;border:none;padding:12px 20px;font-size:.9rem;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--transition-normal);border-radius:var(--border-radius-md) var(--border-radius-md) 0 0}.tab-nav-btn:hover{color:var(--color-primary);background-color:#6366f10a}.tab-nav-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);background-color:#6366f114}.legal-content-wrapper{display:flex;flex-direction:column;gap:20px;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.legal-action-bar-new{display:flex;justify-content:space-between;align-items:center;gap:16px;background-color:var(--bg-secondary);padding:16px 20px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap}.search-box-new{position:relative;flex:1;min-width:280px}.search-box-new input{width:100%;padding:10px 14px 10px 40px;border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-normal)}.search-box-new input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f126}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-secondary)}.filter-dropdown-group{display:flex;align-items:center;gap:10px;font-size:.875rem;font-weight:600;color:var(--text-secondary)}.type-select{padding:8px 12px;border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-weight:500;outline:none;cursor:pointer;transition:border-color var(--transition-normal)}.type-select:focus{border-color:var(--color-primary)}.legal-grid-panel-new{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:24px;max-height:calc(100vh - 240px);overflow-y:auto}.laws-grid-new{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.law-card-new{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:20px;display:flex;flex-direction:column;gap:14px;transition:all var(--transition-normal);position:relative;overflow:hidden}.law-card-new:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#6366f14d}.law-card-new.NATIONAL_LAW:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary)}.law-card-new.COMPANY_POLICY:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:#10b981}.law-card-header-new{display:flex;justify-content:space-between;align-items:center}.law-badge-group-new{display:flex;align-items:center;gap:6px}.law-card-icon-new{width:15px;height:15px;color:var(--text-secondary)}.law-card-new.NATIONAL_LAW .law-card-icon-new{color:var(--color-primary)}.law-card-new.COMPANY_POLICY .law-card-icon-new{color:#10b981}.law-badge-new{font-size:.725rem;font-weight:750;text-transform:uppercase;letter-spacing:.05em}.law-card-new.NATIONAL_LAW .law-badge-new{color:var(--color-primary)}.law-card-new.COMPANY_POLICY .law-badge-new{color:#10b981}.article-badge-new{font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:4px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.law-card-new.NATIONAL_LAW .article-badge-new{background-color:#6366f114;color:var(--color-primary)}.law-card-new.COMPANY_POLICY .article-badge-new{background-color:#10b98114;color:#10b981}.law-card-title-new{font-size:.95rem;font-weight:700;color:var(--text-primary);line-height:1.4;margin:0}.law-card-meta{display:flex;gap:12px;font-size:.725rem;color:var(--text-muted);align-items:center}.meta-item{display:flex;align-items:center;gap:4px}.meta-icon{color:var(--text-muted)}.law-card-content-new{font-size:.8rem;color:var(--text-secondary);line-height:1.6;white-space:pre-line;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;margin:0}.law-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:12px;border-top:1px dashed var(--border-color);gap:12px}.law-keywords-new{display:flex;flex-wrap:wrap;gap:4px;flex:1}.keyword-tag-new{font-size:.65rem;background-color:var(--bg-tertiary);color:var(--text-secondary);padding:2px 6px;border-radius:4px;font-weight:500}.law-action-buttons{display:flex;gap:6px;flex-shrink:0}.action-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);width:30px;height:30px;border-radius:var(--border-radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal)}.action-btn:hover{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.action-btn.delete:hover{background-color:#ef4444;border-color:#ef4444}.action-btn.download:hover{background-color:#059669;border-color:#059669}.loading-state-new,.no-laws-state-new{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;color:var(--text-muted);gap:16px;text-align:center}.no-data-icon-new{width:48px;height:48px;color:var(--border-color)}.upload-section{display:flex;justify-content:center;align-items:center;width:100%;padding:12px 0}.upload-container-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:32px;width:100%}.upload-container-card h4{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin-bottom:6px}.upload-container-card .subtitle,.feed-header-actions .subtitle{font-size:.825rem;color:var(--text-secondary);margin-bottom:24px}.upload-form-split{display:flex;gap:28px;flex-wrap:wrap;width:100%}.upload-left-pane{flex:1;min-width:280px;display:flex;flex-direction:column;gap:16px}.upload-right-pane{flex:1.2;min-width:320px;display:flex;flex-direction:column;gap:16px}.dropzone{border:2px dashed var(--border-color);border-radius:var(--border-radius-lg);padding:44px 20px;text-align:center;cursor:pointer;transition:all var(--transition-normal);background-color:var(--bg-primary);display:flex;align-items:center;justify-content:center;min-height:195px}.dropzone:hover,.dropzone.dragover{border-color:var(--color-primary);background-color:#6366f105}.dropzone.has-file{border-color:#10b981;background-color:#10b98105}.file-hidden-input{display:none}.dropzone-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.upload-icon{width:40px;height:40px;color:var(--text-muted);transition:color var(--transition-normal)}.dropzone:hover .upload-icon{color:var(--color-primary)}.dropzone.has-file .upload-icon{color:#10b981}.dropzone .formats{font-size:.725rem;color:var(--text-muted)}.selected-file-info{display:flex;flex-direction:column;gap:4px}.selected-file-info .filename{font-size:.9rem;font-weight:700;color:var(--text-primary)}.selected-file-info .filesize{font-size:.775rem;color:var(--text-secondary)}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.85rem;font-weight:700;color:var(--text-primary)}.form-group input,.form-group select{padding:10px 14px;border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;outline:none;transition:border-color var(--transition-normal)}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary)}.custom-select-box{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' 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 14px center;background-size:16px;padding-right:40px!important;cursor:pointer}.submit-upload-btn-new{background-color:var(--color-primary);border:none;color:#fff;padding:12px 24px;font-size:.9rem;font-weight:700;border-radius:var(--border-radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color var(--transition-normal);width:100%}.submit-upload-btn-new:hover:not(:disabled){background-color:#4f46e5}.submit-upload-btn-new:disabled{background-color:var(--border-color);color:var(--text-muted);cursor:not-allowed}.btn-icon-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.feed-header-actions{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.feed-header-actions h4{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin-bottom:6px}.feed-buttons{display:flex;gap:10px}.feed-action-btn{padding:10px 18px;font-size:.85rem;font-weight:700;border-radius:var(--border-radius-md);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all var(--transition-normal)}.feed-action-btn.refresh{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.feed-action-btn.refresh:hover:not(:disabled){background-color:var(--bg-tertiary)}.feed-action-btn.sync{background-color:var(--color-primary);border:none;color:#fff}.feed-action-btn.sync:hover:not(:disabled){background-color:#4f46e5}.feed-action-btn:disabled{opacity:.6;cursor:not-allowed}.feed-action-btn .spin{animation:spin 1.2s linear infinite}.feed-list-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:24px;max-height:calc(100vh - 240px);overflow-y:auto}.feed-list{display:flex;flex-direction:column;gap:16px}.feed-item-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:18px;display:flex;flex-direction:column;gap:10px;transition:border-color var(--transition-normal)}.feed-item-card:hover{border-color:#6366f140}.feed-item-card.synced{border-left:4px solid #10b981}.feed-item-card.pending{border-left:4px solid #f59e0b}.feed-item-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.status-badge{display:flex;align-items:center;gap:8px}.badge{font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:9999px;display:flex;align-items:center}.badge.success{background-color:#10b9811a;color:#059669}.badge.warning{background-color:#f59e0b1a;color:#d97706}.feed-doc-type{font-size:.7rem;color:var(--text-muted);font-weight:500}.feed-doc-identity{font-size:.725rem;font-weight:700;color:var(--text-primary);background-color:var(--bg-tertiary);padding:2px 6px;border-radius:4px}.feed-doc-title{font-size:.9rem;font-weight:700;color:var(--text-primary);line-height:1.4;margin:0}.feed-doc-meta{display:flex;gap:16px;font-size:.725rem;color:var(--text-secondary);flex-wrap:wrap}.feed-doc-preview-text{font-size:.8rem;color:var(--text-secondary);line-height:1.5;background-color:var(--bg-tertiary);padding:10px 12px;border-radius:var(--border-radius-sm)}.feed-download-link{margin-top:4px}.pdf-link-btn{font-size:.725rem;font-weight:600;color:var(--color-primary);text-decoration:none;display:inline-flex;align-items:center}.pdf-link-btn:hover{text-decoration:underline}.preview-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.preview-modal-content{background-color:var(--bg-primary);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-title-group{display:flex;align-items:center;gap:14px}.modal-logo{width:24px;height:24px;color:var(--color-primary)}.modal-title-group h4{font-size:1.05rem;font-weight:800;color:var(--text-primary);line-height:1.4;margin:0 0 2px}.modal-title-group p{font-size:.775rem;color:var(--text-secondary);margin:0}.close-modal-btn{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0}.close-modal-btn:hover{color:var(--text-primary)}.modal-body{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.metadata-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px;background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius-md);border:1px solid var(--border-color)}.metadata-item{display:flex;flex-direction:column;gap:4px}.metadata-item.full{grid-column:span 2}.metadata-item .label{font-size:.725rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.metadata-item .value{font-size:.85rem;color:var(--text-primary);font-weight:600}.document-content-view{display:flex;flex-direction:column;gap:8px}.document-content-view h5{font-size:.875rem;font-weight:700;color:var(--text-primary);margin:0}.document-content-view pre{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:16px;font-family:inherit;font-size:.825rem;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;max-height:360px;overflow-y:auto}.document-content-view pre::-webkit-scrollbar{width:6px}.document-content-view pre::-webkit-scrollbar-track{background:transparent}.document-content-view pre::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.document-content-view pre::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}.download-btn-primary{background-color:#059669;border:none;color:#fff;padding:8px 16px;font-size:.85rem;font-weight:700;border-radius:var(--border-radius-md);text-decoration:none;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.download-btn-primary:hover{background-color:#047857}.close-btn-secondary{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:8px 16px;font-size:.85rem;font-weight:700;border-radius:var(--border-radius-md);cursor:pointer;transition:background-color var(--transition-normal)}.close-btn-secondary:hover{background-color:var(--bg-tertiary)}.law-list-new{display:flex;flex-direction:column;gap:12px;width:100%}.law-row-new{display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:14px 20px;transition:all var(--transition-normal);gap:20px;width:100%}.law-row-new:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--color-primary)}.law-row-new.NATIONAL_LAW{border-left:4px solid var(--color-primary)}.law-row-new.COMPANY_POLICY{border-left:4px solid #10b981}.law-row-left{display:flex;align-items:center;gap:16px;flex:1;min-width:0}.law-row-icon-wrapper{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background-color:var(--bg-tertiary);flex-shrink:0}.law-row-new.NATIONAL_LAW .law-row-icon{color:var(--color-primary)}.law-row-new.COMPANY_POLICY .law-row-icon{color:#10b981}.law-row-icon{width:20px;height:20px}.law-row-details{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.law-row-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.law-row-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:600px}.law-row-badge{font-size:.675rem;font-weight:750;padding:2px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.03em}.law-row-badge.NATIONAL_LAW{background-color:#6366f114;color:var(--color-primary)}.law-row-badge.COMPANY_POLICY{background-color:#10b98114;color:#10b981}.law-row-lawname-badge{font-size:.7rem;color:var(--text-muted);background-color:var(--bg-tertiary);padding:2px 8px;border-radius:4px;font-weight:600}.law-row-meta{display:flex;align-items:center;gap:16px;font-size:.775rem;color:var(--text-secondary);flex-wrap:wrap}.keyword-tag-mini{background-color:var(--bg-tertiary);color:var(--text-secondary);padding:1px 6px;border-radius:4px;font-size:.725rem;margin-right:4px;border:1px solid var(--border-color);font-weight:600}.law-row-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.action-btn-row{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--border-radius-sm);border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal)}.action-btn-row:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.action-btn-row.preview:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:#6366f105}.action-btn-row.download:hover{border-color:#10b981;color:#10b981;background-color:#10b98105}.action-btn-row.delete:hover{border-color:var(--color-danger);color:var(--color-danger);background-color:var(--color-danger-bg)}.upload-file-list{display:flex;flex-direction:column;gap:8px;width:100%;max-height:160px;overflow-y:auto;padding:6px;background-color:var(--bg-tertiary);border-radius:var(--border-radius-md);border:1px solid var(--border-color);margin-bottom:8px}.upload-file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.8rem;gap:10px}.upload-file-item .file-name{font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;text-align:left}.upload-file-item .file-size{color:var(--text-muted);font-size:.725rem;flex-shrink:0}.remove-file-btn{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;line-height:1;padding:0 4px;transition:color var(--transition-normal)}.remove-file-btn:hover{color:var(--color-danger)}.disabled-input{background-color:var(--bg-tertiary)!important;color:var(--text-muted)!important;cursor:not-allowed;border-style:dashed!important}.upload-form-new{display:flex;flex-direction:column;gap:20px;width:100%}.dropzone-full{width:100%;border:2px dashed var(--border-color);border-radius:var(--border-radius-md);padding:20px;text-align:center;background-color:var(--bg-secondary);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.dropzone-full:hover,.dropzone-full.dragover{border-color:var(--color-primary);background-color:#6366f105}.dropzone-full.has-file{border-color:#10b981;background-color:#10b98105}.dropzone-label-full{display:flex;align-items:center;justify-content:center;gap:16px;cursor:pointer;width:100%}.upload-icon-full{width:28px;height:28px;color:var(--text-secondary)}.selected-file-info-full{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.filename-full{font-weight:700;color:var(--text-primary);font-size:1rem}.filesize-full{font-size:.775rem;color:var(--text-muted)}.formats-full{font-size:.775rem;color:var(--text-muted);margin-top:4px}.upload-queue-container{display:flex;flex-direction:column;gap:12px;width:100%}.upload-queue-list-rows{display:flex;flex-direction:column;gap:10px;width:100%;max-height:450px;overflow-y:auto;padding:4px}.upload-queue-list-rows::-webkit-scrollbar{width:6px}.upload-queue-list-rows::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.upload-queue-list-rows::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.upload-queue-row{display:flex;align-items:center;gap:16px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:12px 18px;transition:all var(--transition-normal);width:100%}.upload-queue-row:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.upload-queue-row.uploading{border-color:var(--color-primary);background-color:#6366f103}.upload-queue-row.success{border-color:#10b981;background-color:#10b98103}.upload-queue-row.error{border-color:var(--color-danger);background-color:#ef444403}.row-file-info{display:flex;align-items:center;gap:10px;width:220px;min-width:220px}.file-icon-row{color:var(--color-primary);flex-shrink:0}.file-name-size{display:flex;flex-direction:column;min-width:0;text-align:left}.file-name-txt-row{font-weight:700;color:var(--text-primary);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size-txt-row{font-size:.7rem;color:var(--text-muted)}.row-field{display:flex;flex-direction:column;gap:4px;text-align:left}.row-field label{font-size:.675rem;font-weight:750;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em}.row-field input,.upload-queue-row select{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:.8rem;transition:border-color var(--transition-normal);outline:none;width:100%}.row-field input:focus,.upload-queue-row select:focus{border-color:var(--color-primary)}.title-field{flex:2;min-width:200px}.type-field{width:160px;min-width:160px}.keywords-field{flex:1.2;min-width:150px}.row-actions-status{display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.remove-row-btn{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;line-height:1;transition:color var(--transition-normal)}.remove-row-btn:hover{color:var(--color-danger)}.row-status-indicator{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-weight:700;font-size:.8rem}.row-status-indicator.uploading{color:var(--color-primary)}.spin-icon-row{animation:spin 1s linear infinite}.row-status-indicator.success{background-color:#10b9811a;color:#10b981}.row-status-indicator.error{background-color:#ef44441a;color:var(--color-danger);cursor:help}.upload-actions-footer{display:flex;justify-content:flex-end;margin-top:10px}.submit-upload-btn-full{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--border-radius-md);border:none;background-color:var(--color-primary);color:#fff;font-weight:700;font-size:.875rem;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 6px #6366f11a}.submit-upload-btn-full:hover:not(:disabled){background-color:#4f46e5;transform:translateY(-1px);box-shadow:0 6px 12px #6366f133}.submit-upload-btn-full:disabled{background-color:var(--border-color);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.batch-actions-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);margin-bottom:16px;width:100%}.checkbox-container-master{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem;font-weight:700;color:var(--text-primary);-webkit-user-select:none;user-select:none}.checkbox-label{color:var(--text-secondary)}.batch-delete-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background-color:var(--color-danger);color:#fff;border:none;border-radius:var(--border-radius-sm);font-size:.8rem;font-weight:700;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 2px 4px #ef44441a}.batch-delete-btn:hover{background-color:#ef4444;transform:translateY(-1px);box-shadow:0 4px 8px #ef444433}.law-row-checkbox-wrapper{display:flex;align-items:center;justify-content:center;padding-right:12px;flex-shrink:0}.law-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.ai-module-container{display:flex;flex-direction:column;gap:20px;height:100%}.ai-action-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;background-color:var(--bg-secondary);padding:16px;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-wrap:wrap}.ai-title{display:flex;align-items:center;gap:12px}.brand-logo-small{width:28px;height:28px}.text-indigo{color:var(--color-primary)}.ai-title h3{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.ai-title p{font-size:.775rem;color:var(--text-secondary)}.active-model-tag{display:flex;align-items:center;gap:6px;background-color:#eeebff;border:1px solid #c7d2fe;color:var(--color-primary);padding:6px 12px;border-radius:var(--border-radius-md);font-size:.8rem;font-weight:600}.model-icon{width:14px;height:14px}.ai-chat-layout{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start;height:calc(100vh - 180px)}@media(max-width:900px){.ai-chat-layout{grid-template-columns:1fr;height:auto}}.chat-window-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-history{flex:1;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;background-color:#f8fafc}.chat-message{display:flex;gap:12px;max-width:80%}.chat-message.user{align-self:flex-end;flex-direction:row-reverse}.chat-message.assistant{align-self:flex-start}.message-avatar{width:32px;height:32px;border-radius:50%;background-color:#e2e8f0;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.chat-message.assistant .message-avatar{background-color:var(--color-primary);color:#fff}.message-bubble{padding:12px 16px;border-radius:var(--border-radius-lg);font-size:.875rem;line-height:1.5}.chat-message.user .message-bubble{background-color:var(--color-primary);color:#fff;border-top-right-radius:0}.chat-message.assistant .message-bubble{background-color:var(--bg-secondary);color:var(--text-primary);border-top-left-radius:0;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);white-space:pre-line}.dot-flashing{position:relative;width:6px;height:6px;border-radius:5px;background-color:var(--color-primary);color:var(--color-primary);animation:dot-flashing 1s infinite linear;margin:6px 12px;display:inline-block}@keyframes dot-flashing{0%{background-color:var(--color-primary)}50%,to{background-color:#4f46e533}}.chat-input-area{padding:16px;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;gap:12px}.chat-input-area input{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);outline:none;font-size:.875rem;background-color:var(--bg-primary)}.chat-input-area input:focus{border-color:var(--color-primary);background-color:#fff}.send-btn{background-color:var(--color-primary);color:#fff;border:none;padding:0 20px;border-radius:var(--border-radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center}.send-btn:hover{background-color:var(--color-primary-hover)}.chat-suggestions-panel{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px;height:100%}.suggestions-list{display:flex;flex-direction:column;gap:10px}.suggestion-card{display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--border-radius-md);border:1px solid var(--border-color);background-color:var(--bg-primary);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.suggestion-card:hover{background-color:#eeebff;border-color:#c7d2fe}.suggestion-card-icon{width:16px;height:16px;color:var(--color-primary);flex-shrink:0}.suggestion-card span{font-size:.8rem;font-weight:600;color:var(--text-primary)}.ai-disclaimer{margin-top:auto;padding:12px;background-color:var(--bg-primary);border:1px dashed var(--border-color);border-radius:var(--border-radius-md);display:flex;gap:10px;align-items:flex-start}.disclaimer-icon{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0;margin-top:2px}.ai-disclaimer p{font-size:.725rem;color:var(--text-secondary);line-height:1.4}.spin-slow{animation:spin 3s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.company-settings-container{display:flex;flex-direction:column;gap:24px;width:100%;padding:8px}.company-settings-header{display:flex;align-items:center;gap:16px;text-align:left}.company-settings-header .header-icon-wrapper{background-color:#6366f11a;color:var(--color-primary);width:48px;height:48px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center}.company-settings-header h1{font-size:1.5rem;font-weight:800;color:var(--text-primary);margin:0 0 4px}.company-settings-header p{font-size:.875rem;color:var(--text-secondary);margin:0}.tab-menu-bar{display:flex;gap:8px;border-bottom:1px solid var(--border-color);padding-bottom:8px;margin-bottom:8px}.tab-btn-item{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;background:none;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.tab-btn-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.tab-btn-item.active{background-color:#6366f11a;color:var(--color-primary)}.company-settings-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:32px;box-shadow:var(--shadow-sm)}.company-settings-form{display:flex;flex-direction:column;gap:24px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group-full{grid-column:span 2;display:flex;flex-direction:column;gap:8px;text-align:left}.form-group-half{grid-column:span 1;display:flex;flex-direction:column;gap:8px;text-align:left}.form-select{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem;transition:all var(--transition-normal);outline:none;width:100%;cursor:pointer}.form-select:focus{border-color:var(--color-primary);background-color:var(--bg-secondary);box-shadow:0 0 0 3px #6366f11a}@media(max-width:600px){.form-group-half{grid-column:span 2}}.company-settings-form label{font-size:.775rem;font-weight:750;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.company-settings-form input{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem;transition:all var(--transition-normal);outline:none;width:100%}.company-settings-form input:focus{border-color:var(--color-primary);background-color:var(--bg-secondary);box-shadow:0 0 0 3px #6366f11a}.company-settings-form input.disabled-input{background-color:var(--bg-tertiary);border-style:dashed;cursor:not-allowed;color:var(--text-muted)}.field-note{font-size:.725rem;color:var(--text-muted);margin-top:-2px}.form-actions-footer{display:flex;justify-content:flex-end;border-top:1px solid var(--border-color);padding-top:20px}.save-settings-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--border-radius-md);background-color:var(--color-primary);color:#fff;font-weight:700;font-size:.875rem;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 6px #6366f11a}.save-settings-btn:hover:not(:disabled){background-color:#4f46e5;transform:translateY(-1px);box-shadow:0 6px 12px #6366f126}.save-settings-btn:disabled{background-color:var(--border-color);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.saas-dashboard-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:24px;width:100%}@media(max-width:1024px){.saas-dashboard-grid{grid-template-columns:1fr}}.saas-list-card,.saas-form-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:20px;text-align:left}.card-header-title{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-color);padding-bottom:12px}.card-header-title h3{font-size:1.1rem;font-weight:750;margin:0;color:var(--text-primary)}.saas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;gap:12px;color:var(--text-secondary)}.saas-table-wrapper{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-tertiary)}.saas-table{width:100%;border-collapse:collapse;font-size:.85rem}.saas-table th,.saas-table td{padding:12px 14px;border-bottom:1px solid var(--border-color);text-align:left;vertical-align:middle}.saas-table th{background-color:var(--bg-secondary);color:var(--text-secondary);font-weight:700;text-transform:uppercase;font-size:.725rem;letter-spacing:.03em}.saas-table tr:last-child td{border-bottom:none}.saas-table tr:hover{background-color:var(--bg-secondary)}.saas-table tr.active-row{background-color:#6366f10a}.comp-name-cell{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.active-badge{font-size:.65rem;background-color:#10b98126;color:#10b981;padding:2px 6px;border-radius:4px;font-weight:700}.comp-meta-cell{display:flex;flex-direction:column;gap:4px}.comp-meta-cell small{color:var(--text-muted)}.action-buttons-group{display:flex;gap:6px}.action-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:6px 10px;border-radius:4px;border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;font-weight:600;font-size:.75rem;transition:all var(--transition-fast)}.action-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background-color:#6366f10d}.action-btn:disabled{opacity:.5;cursor:not-allowed}.saas-create-form{display:flex;flex-direction:column;gap:20px}.saas-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.saas-form-group{display:flex;flex-direction:column;gap:6px;text-align:left}.saas-form-group-full{grid-column:span 2;display:flex;flex-direction:column;gap:6px;text-align:left}.saas-form-group label,.saas-form-group-full label{font-size:.75rem;font-weight:700;color:var(--text-secondary)}.saas-create-form input,.saas-create-form select{padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:.875rem;outline:none;width:100%;transition:all var(--transition-fast)}.saas-create-form input:focus,.saas-create-form select:focus{border-color:var(--color-primary);background-color:var(--bg-secondary);box-shadow:0 0 0 3px #6366f114}.saas-create-form input.disabled-input{background-color:var(--bg-tertiary);border-style:dashed;color:var(--text-muted);cursor:not-allowed}.password-highlight-group{border-top:1px dashed var(--border-color);padding-top:12px;margin-top:6px}.saas-form-actions{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--border-color);padding-top:16px;margin-top:8px}.saas-cancel-btn{padding:10px 18px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:transparent;color:var(--text-secondary);font-weight:600;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.saas-cancel-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.saas-submit-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--border-radius-md);background-color:var(--color-primary);color:#fff;font-weight:700;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.saas-submit-btn:hover:not(:disabled){background-color:#4f46e5;transform:translateY(-1px)}.saas-submit-btn:disabled{background-color:var(--border-color);color:var(--text-muted);cursor:not-allowed}.saas-access-warning{display:flex;align-items:center;gap:8px;background-color:#f59e0b14;border:1px solid rgba(245,158,11,.2);color:#d97706;padding:10px 14px;border-radius:var(--border-radius-md);font-size:.75rem}.spinner-small{width:18px;height:18px;border:2px solid var(--border-color);border-top:2px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.auto-id-hint{font-style:italic;color:var(--text-muted)!important;background-color:var(--bg-tertiary)!important;border-style:dashed!important}.field-note{font-size:.72rem;color:var(--text-muted);line-height:1.3}.app-init-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:var(--text-secondary);background-color:var(--bg-primary)}.auth-fullscreen-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(circle at 10% 20%,#6366f126,#0000 50%),radial-gradient(circle at 90% 80%,#10b9811a,#0000 50%),#0f172a;padding:24px}.auth-glass-panel{background:#1e293bb3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:var(--border-radius-lg);width:100%;max-width:520px;padding:40px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;gap:24px}.auth-brand{text-align:center}.auth-logo{width:48px;height:48px;color:#6366f1;margin-bottom:12px}.auth-brand h1{font-size:1.5rem;font-weight:800;letter-spacing:-.025em;color:#f8fafc;margin-bottom:6px}.auth-brand p{font-size:.85rem;color:#94a3b8}.auth-error-banner{background-color:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:12px 16px;border-radius:var(--border-radius-md);font-size:.8rem;font-weight:500}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-input-group,.auth-input-group-full{display:flex;flex-direction:column;gap:6px}.auth-grid-inputs{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media(max-width:500px){.auth-grid-inputs{grid-template-columns:1fr}}.auth-input-group-full{grid-column:span 2}@media(max-width:500px){.auth-input-group-full{grid-column:span 1}}.auth-form label{font-size:.775rem;font-weight:600;color:#cbd5e1}.auth-form input{padding:12px;background-color:#0f172a99;border:1px solid #475569;border-radius:var(--border-radius-md);color:#fff;font-size:.875rem;outline:none;transition:all var(--transition-fast)}.auth-form input:focus{border-color:#6366f1;background-color:#0f172acc;box-shadow:0 0 0 3px #6366f133}.auth-submit-btn{background-color:#4f46e5;color:#fff;border:none;padding:12px;border-radius:var(--border-radius-md);font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background var(--transition-fast)}.auth-submit-btn:hover{background-color:#4338ca}.btn-icon-small{width:16px;height:16px}.auth-switch-prompt{text-align:center;font-size:.8rem;color:#94a3b8;margin-top:10px}.auth-switch-prompt button{background:transparent;border:none;color:#6366f1;font-weight:600;cursor:pointer}.auth-switch-prompt button:hover{text-decoration:underline}.app-layout-root{display:flex;width:100vw;height:100vh;overflow:hidden}.app-main-content{flex:1;height:100vh;overflow-y:auto;padding:32px;background-color:var(--bg-primary)}.toast-notification{position:fixed;top:24px;right:24px;display:flex;align-items:center;gap:12px;background-color:var(--bg-secondary);border:1px solid var(--border-color);padding:14px 20px;border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);z-index:9999;min-width:320px;max-width:480px;animation:toast-slide-in .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes toast-slide-in{0%{transform:translate(120%) translateY(0);opacity:0}to{transform:translate(0) translateY(0);opacity:1}}.toast-notification.success{border-left:4px solid var(--color-success);background-color:#f0fdf4}.toast-notification.success .toast-icon{color:var(--color-success)}.toast-notification.error{border-left:4px solid var(--color-danger);background-color:#fef2f2}.toast-notification.error .toast-icon{color:var(--color-danger)}.toast-notification.warning{border-left:4px solid var(--color-warning);background-color:#fffbeb}.toast-notification.warning .toast-icon{color:var(--color-warning)}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-message{font-size:.85rem;font-weight:500;color:var(--text-primary);flex:1}.toast-close-btn{background:transparent;border:none;font-size:1.25rem;color:var(--text-secondary);cursor:pointer;padding:4px;line-height:1;transition:color var(--transition-fast)}.toast-close-btn:hover{color:var(--text-primary)}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:confirm-fade-in .2s ease-out forwards}.confirm-modal-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:440px;padding:24px;display:flex;flex-direction:column;gap:16px;animation:confirm-scale-up .25s cubic-bezier(.16,1,.3,1) forwards}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}@keyframes confirm-scale-up{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.confirm-modal-header{display:flex;align-items:center;gap:12px;color:var(--text-primary)}.confirm-icon{color:var(--color-warning);flex-shrink:0}.confirm-modal-header h3{font-size:1.125rem;font-weight:700;margin:0}.confirm-modal-body p{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin:0;text-align:left}.confirm-modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:4px}.confirm-btn-cancel,.confirm-btn-ok{padding:9px 18px;font-size:.85rem;font-weight:600;border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-fast)}.confirm-btn-cancel{background-color:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.confirm-btn-cancel:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.confirm-btn-ok{background-color:var(--color-primary);border:none;color:#fff}.confirm-btn-ok:hover{background-color:#4f46e5}:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-success: #10b981;--color-success-bg: #ecfdf5;--color-warning: #f59e0b;--color-warning-bg: #fffbeb;--color-danger: #ef4444;--color-danger-bg: #fef2f2;--border-color: #e2e8f0;--border-radius-sm: 6px;--border-radius-md: 10px;--border-radius-lg: 16px;--font-family: "Outfit", "Inter", system-ui, -apple-system, sans-serif;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .25s ease}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}::-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}
