:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background-color:#2a1a4a;background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:480px;animation:slideIn .3s ease-out;color:#333}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.login-header h1{color:#333;font-size:32px;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:#666;font-size:14px;line-height:1.5}.message{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;animation:fadeIn .3s ease-in}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#333;font-size:14px;font-weight:600}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;transition:all .3s ease;background-color:#fafafa;color:#333}.form-group input:focus{outline:none;border-color:#667eea;background-color:#fff;color:#333;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#e74c3c;background-color:#fff5f5;color:#333}.error-text{color:#e74c3c;font-size:12px;margin-top:4px}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#666}.checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.forgot-password{color:#667eea;text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.forgot-password:hover{color:#764ba2;text-decoration:underline}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.toggle-mode{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #e0e0e0}.toggle-mode p{color:#666;font-size:14px}.toggle-btn{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;font-size:14px;text-decoration:underline;padding:0;transition:color .2s}.toggle-btn:hover{color:#764ba2}@media (max-width: 768px){.login-card{padding:30px 20px}.login-header h1{font-size:28px}.form-row{grid-template-columns:1fr}}.success-message{background:#d4edda;border:1px solid #c3e6cb;color:#155724;padding:12px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.date-input{width:100%;padding:8px 12px;border:2px solid #667eea;border-radius:6px;font-size:14px;background:#f8f9fa;transition:all .2s ease}.date-input:focus{outline:none;border-color:#764ba2;box-shadow:0 0 0 3px #667eea1a;background:#fff}.no-date{color:#999;font-style:italic;opacity:.7}.btn-edit,.btn-save,.btn-cancel{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;white-space:nowrap}.btn-edit{background:#667eea;color:#fff}.btn-edit:hover{background:#764ba2;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.btn-save{background:#51cf66;color:#fff}.btn-save:hover{background:#37b24d;transform:translateY(-1px);box-shadow:0 4px 8px #51cf664d}.btn-cancel{background:#e9ecef;color:#495057}.btn-cancel:hover{background:#dee2e6;transform:translateY(-1px)}.entities-table tbody td:last-child{text-align:center}.entities-table tbody tr.editing{background-color:#f0f4ff}@media (max-width: 768px){.action-buttons{flex-direction:column}.btn-edit,.btn-save,.btn-cancel{width:100%}.date-input{font-size:16px}}.btn-add{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-add:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:12px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:10px;animation:slideDown .3s ease}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-active{background:#d4edda;color:#155724}.status-inactive{background:#f8d7da;color:#721c24}.category-badge{background:#e7f3ff;color:#06c;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.no-category{color:#999;font-style:italic}.btn-delete{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;background:#ff6b6b;color:#fff}.btn-delete:hover{background:#ee5a52;transform:translateY(-1px);box-shadow:0 4px 8px #ff6b6b4d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e9ecef}.modal-header h2{margin:0;font-size:24px;color:#333}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999;transition:color .2s ease;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#333}.modal-content form{padding:24px}.form-group input[type=text],.form-group input[type=number],.form-group textarea{width:100%;padding:10px 14px;border:2px solid #dee2e6;border-radius:8px;font-size:14px;transition:all .2s ease;font-family:inherit}.form-group textarea{resize:vertical;min-height:80px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-group{display:flex;align-items:center}.checkbox-group label{display:flex;align-items:center;gap:10px;cursor:pointer;margin:0}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.checkbox-group span{font-weight:500;color:#495057}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e9ecef;margin:0 -24px -24px}.modal-footer .btn-cancel{background:#e9ecef;color:#495057;padding:10px 24px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.modal-footer .btn-cancel:hover{background:#dee2e6}.modal-footer .btn-save{background:linear-gradient(135deg,#51cf66,#37b24d);color:#fff;padding:10px 24px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.modal-footer .btn-save:hover{transform:translateY(-1px);box-shadow:0 4px 12px #51cf664d}.nav-group{position:relative}.nav-group>a{display:flex;align-items:center;justify-content:space-between;width:100%}.nav-arrow{font-size:12px;transition:transform .3s ease;margin-left:auto}.nav-group.open .nav-arrow{transform:rotate(90deg)}.submenu{list-style:none;padding:0;margin:0;background:#0000001a;border-radius:8px;overflow:hidden;animation:expandMenu .3s ease}@keyframes expandMenu{0%{max-height:0;opacity:0}to{max-height:200px;opacity:1}}.submenu .nav-item{padding-left:20px}.submenu .nav-item a{padding:10px 16px;font-size:14px}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.form-row{grid-template-columns:1fr}.btn-add{font-size:12px;padding:8px 16px}}.back-btn{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;margin-bottom:10px;display:inline-flex;align-items:center;gap:6px}.back-btn:hover{background:#5a6268;transform:translate(-3px)}.entity-code{color:#666;font-size:14px;margin:5px 0 0}.date-duration-section{display:flex;gap:30px;padding:20px;background:#fff;border-radius:12px;margin-bottom:25px;box-shadow:0 2px 4px #0000000d;flex-wrap:wrap;align-items:flex-end}.date-duration-group{display:flex;flex-direction:column;gap:8px;flex:1;min-width:200px}.date-duration-group label{font-weight:600;color:#333;font-size:14px}.date-input,.duration-input{padding:10px 14px;border:2px solid #dee2e6;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s ease;background:#fff}.date-input:focus,.duration-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.duration-input{max-width:150px}.calculated-date{padding:10px 14px;background:#f0f7ff;border:2px solid #4dabf7;border-radius:6px;font-size:14px;font-weight:600;color:#1864ab}.btn-save-metadata{padding:10px 20px;background:linear-gradient(135deg,#51cf66,#37b24d);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px;justify-content:center;align-self:flex-end}.btn-save-metadata:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #51cf6666}.btn-save-metadata:disabled{opacity:.5;cursor:not-allowed}.project-summary-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:25px 30px;border-radius:12px;margin-bottom:25px;box-shadow:0 4px 12px #667eea4d}.project-summary-section h3{margin:0 0 20px;font-size:18px;font-weight:700;display:flex;align-items:center;gap:10px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.summary-item{background:#ffffff26;padding:15px 20px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.summary-item label{display:block;font-size:13px;font-weight:600;opacity:.9;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:18px;font-weight:700;color:#fff}.predecessor-tag{display:inline-block;padding:4px 8px;background:#e3f2fd;color:#1976d2;border-radius:4px;font-size:12px;font-weight:600;cursor:help}@media (max-width: 768px){.date-duration-section{flex-direction:column;align-items:stretch}.date-duration-group{min-width:100%}.duration-input{max-width:100%}.summary-grid{grid-template-columns:1fr}.project-summary-section{padding:20px}.summary-item{padding:12px 15px}}.btn-load-template{background:linear-gradient(135deg,#4dabf7,#339af0);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-load-template:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4dabf766}.btn-update-predecessors{background:linear-gradient(135deg,#845ef7,#7048e8);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-update-predecessors:hover{transform:translateY(-2px);box-shadow:0 6px 20px #845ef766;background:linear-gradient(135deg,#7950f2,#6741d9)}.btn-update-durations{background:linear-gradient(135deg,#ff922b,#fd7e14);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-update-durations:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff922b66;background:linear-gradient(135deg,#fd7e14,#f76707)}.btn-auto-schedule{background:linear-gradient(135deg,#20c997,#12b886);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-auto-schedule:hover{transform:translateY(-2px);box-shadow:0 6px 20px #20c99766;background:linear-gradient(135deg,#12b886,#0ca678)}.btn-clear-checklist{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-clear-checklist:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66;background:linear-gradient(135deg,#fa5252,#e03131)}.btn-check-all{background:linear-gradient(135deg,#51cf66,#37b24d);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-check-all:hover{transform:translateY(-2px);box-shadow:0 6px 20px #51cf6666;background:linear-gradient(135deg,#40c057,#2f9e44)}.progress-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px}.progress-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 6px #00000012;display:flex;gap:16px;align-items:center;transition:transform .3s ease,box-shadow .3s ease}.progress-card:hover{transform:translateY(-3px);box-shadow:0 8px 15px #0000001f}.progress-card .card-icon{font-size:40px;line-height:1}.progress-card .card-content{flex:1}.progress-card h3{margin:0 0 6px;font-size:13px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.progress-card .card-value{margin:0;font-size:32px;font-weight:700;line-height:1.2;color:#333}.card-total{border-left:4px solid #667eea}.card-completed{border-left:4px solid #51cf66}.card-pending{border-left:4px solid #ffa94d}.card-percentage{border-left:4px solid #4dabf7}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#51cf66,#37b24d);transition:width .5s ease;border-radius:4px}.status-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#51cf66;transform:scale(1.2)}.completed-row{background-color:#f0f9f4!important;opacity:.85}.completed-row .item-text{text-decoration:line-through;color:#6c757d}.item-text{font-weight:500;color:#333;line-height:1.4}.item-comments{font-size:12px;color:#666;font-style:italic;margin-top:4px;padding:4px 8px;background:#f8f9fa;border-radius:4px;display:inline-block}.editable-cell{cursor:pointer;position:relative;transition:all .2s ease}.editable-cell:hover{background-color:#fff3cd;border-radius:3px;padding:2px 4px;box-shadow:inset 0 0 0 1px #ffeaa7}.inline-edit-cell{display:flex;gap:6px;align-items:center;padding:4px;background:#fff;border:2px solid #667eea;border-radius:6px}.inline-edit-select,.inline-edit-textarea,.inline-edit-input{flex:1;border:1px solid #dee2e6;border-radius:4px;padding:6px 8px;font-size:13px;font-family:inherit}.inline-edit-textarea{min-height:60px;resize:vertical}.inline-edit-select:focus,.inline-edit-textarea:focus,.inline-edit-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.inline-save-btn,.inline-cancel-btn{padding:4px 10px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:all .2s ease}.inline-save-btn{background:#51cf66;color:#fff}.inline-save-btn:hover{background:#37b24d;transform:scale(1.05)}.inline-cancel-btn{background:#e9ecef;color:#495057}.inline-cancel-btn:hover{background:#dee2e6;transform:scale(1.05)}.modal-small{max-width:450px}.modal-body p{color:#666;line-height:1.6;margin-bottom:20px}.header-actions{display:flex;gap:12px;align-items:center}@media (max-width: 768px){.progress-cards{grid-template-columns:1fr}.header-actions{flex-direction:column;align-items:stretch}.btn-add,.btn-load-template{width:100%;justify-content:center}.back-btn{margin-bottom:15px}}.form-select{width:100%;padding:10px 14px;border:2px solid #dee2e6;border-radius:8px;font-size:14px;transition:all .2s ease;font-family:inherit;background:#fff;cursor:pointer}.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-select:disabled{background-color:#e9ecef;cursor:not-allowed;opacity:.6}.main-content{flex:1;min-height:100vh;transition:margin-left .3s ease;margin-left:0;padding:0}.filters-section{background:#fff;padding:20px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 4px #0000000d;display:flex;gap:15px;flex-wrap:wrap}.filter-group{flex:1;min-width:200px}.filter-input-search{width:100%;padding:10px 15px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:all .2s ease}.employees-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #00000012}.employees-table{width:100%;border-collapse:collapse;font-size:14px}.employees-table thead{background:#f8f9fa}.employees-table th{padding:12px 16px;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6}.employees-table th[style*="cursor: pointer"]{-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.employees-table th[style*="cursor: pointer"]:hover{background-color:#e9ecef}.employees-table td{padding:12px 16px;border-bottom:1px solid #e9ecef;color:#495057}.employees-table tbody tr{transition:background-color .2s ease}.employees-table tbody tr:hover{background-color:#f8f9fa}.role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;background:#e3f2fd;color:#1976d2}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.btn-add-new{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-add-new:hover{background:#764ba2;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.header-actions{display:flex;gap:10px}.action-buttons{display:flex;gap:8px;justify-content:center}.btn-edit-small,.btn-delete-small{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.btn-edit-small{background:#667eea;color:#fff}.btn-edit-small:hover{background:#764ba2;transform:translateY(-1px)}.btn-delete-small{background:#ff6b6b;color:#fff}.btn-delete-small:hover{background:#ee5a52;transform:translateY(-1px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-small{max-width:400px}.modal-header h2{margin:0;font-size:22px;color:#333}.modal-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f8f9fa;color:#333}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.rate-field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#495057;font-size:14px}.rate-field-header label{margin-bottom:0}.btn-view-rate-inline,.btn-hide-rate-inline{background:none;border:1px solid #ffa94d;color:#ffa94d;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.btn-view-rate-inline:hover{background:#ffa94d;color:#fff}.btn-hide-rate-inline{border-color:#51cf66;color:#51cf66}.btn-hide-rate-inline:hover{background:#51cf66;color:#fff}.form-input,.form-select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:all .2s ease}.form-input:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled{background:#e9ecef;cursor:not-allowed}.form-select{cursor:pointer}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:400}.form-checkbox{width:18px;height:18px;cursor:pointer}.btn-cancel-modal,.btn-submit-modal{padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.btn-cancel-modal{background:#e9ecef;color:#495057}.btn-cancel-modal:hover{background:#dee2e6}.btn-submit-modal{background:#667eea;color:#fff}.btn-submit-modal:hover{background:#764ba2;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.password-error{color:#dc3545;font-size:13px;margin-top:8px;font-weight:500;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.rate-column{font-weight:600;color:#28a745;font-family:Courier New,monospace}.btn-export-excel,.btn-export-pdf{padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;white-space:nowrap}.btn-export-excel{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-export-excel:hover{transform:translateY(-2px);box-shadow:0 6px 12px #10b98166}.btn-export-pdf{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-export-pdf:hover{transform:translateY(-2px);box-shadow:0 6px 12px #f59e0b66}@media (max-width: 768px){.filters-section{flex-direction:column}.filter-group{min-width:100%}.form-row{grid-template-columns:1fr}.modal-content{width:95%;max-height:95vh}.employees-table{font-size:12px}.employees-table th,.employees-table td{padding:8px 12px}.action-buttons{flex-direction:column}}.page-header{margin-bottom:20px}.page-header h1{font-size:28px;color:#333;margin:0 0 8px;font-weight:700}.page-header .subtitle{font-size:14px;color:#666;margin:0}.report-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #00000012;margin-top:20px;color:#333}.report-table{width:100%;border-collapse:collapse;font-size:14px}.report-table thead{background:#f8f9fa}.report-table th{padding:12px 16px;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6;white-space:nowrap}.report-table th[style*="cursor: pointer"]{-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.report-table th[style*="cursor: pointer"]:hover{background-color:#e9ecef}.report-table td{padding:12px 16px;border-bottom:1px solid #e9ecef;color:#495057}.report-table tbody tr{transition:background-color .2s ease}.report-table tbody tr:hover{background-color:#f8f9fa}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table thead{background:#f8f9fa}.data-table th{padding:12px 16px;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6;white-space:nowrap;-webkit-user-select:none;user-select:none}.data-table th:hover{background-color:#e9ecef}.data-table td{padding:12px 16px;border-bottom:1px solid #e9ecef;color:#495057}.data-table tbody tr{transition:background-color .2s ease}.data-table tbody tr:hover{background-color:#f8f9fa}.no-data{text-align:center;padding:30px!important;color:#999;font-style:italic}.table-container{background:#fff;border-radius:12px;overflow-x:auto;margin-top:20px;box-shadow:0 2px 4px #0000000d;padding:20px}.text-right{text-align:right;font-family:Courier New,monospace;font-weight:600}.positive-diff{color:#28a745;font-weight:700}.negative-diff{color:#dc3545;font-weight:700}.card-value-small{margin:0;font-size:24px;font-weight:700;line-height:1.2;color:#333}.card-value-split{display:flex;gap:15px;font-size:28px;font-weight:700;line-height:1.2}.card-value-split .positive{color:#28a745}.card-value-split .negative{color:#dc3545}.card-info-alt{border-left:4px solid #20c997}.card-stats{border-left:4px solid #6f42c1}.btn-refresh{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-refresh:hover{background:#764ba2;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.filters-section{background:#fff;padding:20px;border-radius:12px;margin-top:20px;box-shadow:0 2px 4px #0000000d;display:flex;gap:15px;flex-wrap:wrap;align-items:flex-end}.filter-group{flex:1;min-width:200px;display:flex;flex-direction:column}.filter-group label{font-weight:600;margin-bottom:5px;color:#333;font-size:14px}.filter-input{width:100%;padding:10px 15px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:all .2s ease;background-color:#fff;color:#333}.filter-input-search{width:100%;padding:10px 15px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:all .2s ease;background-color:#fff;color:#333}.filter-input-search:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-select{width:100%;padding:10px 15px;border:1px solid #ced4da;border-radius:6px;font-size:14px;background:#fff;color:#333;cursor:pointer;transition:all .2s ease}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-info{font-size:13px;color:#666;white-space:nowrap;padding-top:25px}.export-buttons{display:flex;gap:10px;flex-wrap:wrap}.btn-export{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;white-space:nowrap}.btn-export:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.btn-export:active{transform:translateY(0);box-shadow:0 2px 4px #667eea66}.btn-excel{background:linear-gradient(135deg,#10b981,#059669)}.btn-excel:hover{box-shadow:0 6px 12px #10b98166}.btn-pdf{background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-pdf:hover{box-shadow:0 6px 12px #f59e0b66}.main-content{flex:1;min-height:100vh;transition:margin-left .3s ease;margin-left:0;padding:0;background-color:#f5f7fa;color:#333}.reports-container{padding:30px;background:#f5f7fa;min-height:100vh}.reports-header{margin-bottom:30px}.reports-header h1{font-size:28px;color:#333;margin:0 0 8px;font-weight:700}.reports-header p{font-size:14px;color:#666;margin:0}.loading{text-align:center;padding:60px 20px;color:#666;font-size:16px}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px}@media (max-width: 768px){.filters-section{flex-direction:column}.filter-group{min-width:100%}.report-table{font-size:12px}.report-table th,.report-table td{padding:8px 12px}.card-value-small{font-size:18px}.card-value-split{font-size:22px}}.badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-align:center;white-space:nowrap}.badge-admin{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.badge-success{background-color:#d4edda;color:#155724}.badge-warning{background-color:#fff3cd;color:#856404}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-info{background-color:#d1ecf1;color:#0c5460}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:700px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease;color:#333}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.delete-progress-modal{min-height:400px}.modal-header{padding:25px 30px;border-bottom:2px solid #e9ecef;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.modal-header h3{margin:0 0 10px;font-size:22px;font-weight:600}.modal-header .employee-name{margin:0;font-size:16px;opacity:.95;font-weight:500}.modal-body{padding:20px 30px;flex:1;overflow-y:auto;background:#f8f9fa}.progress-logs{background:#1e1e1e;border-radius:8px;padding:20px;font-family:Consolas,Monaco,Courier New,monospace;font-size:13px;line-height:1.6;color:#d4d4d4;max-height:400px;overflow-y:auto;box-shadow:inset 0 2px 4px #0003}.log-entry{padding:4px 0;transition:all .2s ease;animation:logFadeIn .3s ease}@keyframes logFadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.log-success{color:#4ec9b0;font-weight:500}.log-error{color:#f48771;font-weight:600}.log-divider{color:gray;font-weight:600;margin:8px 0}.log-processing{color:#dcdcaa;font-style:italic}.spinner{display:inline-block;animation:spin 1s linear infinite;margin-right:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-footer{padding:20px 30px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;align-items:center;background:#fff;border-radius:0 0 12px 12px}.btn-close-modal{padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #667eea4d}.btn-close-modal:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.modal-note{margin:0;color:#6c757d;font-size:13px;font-style:italic}.progress-logs::-webkit-scrollbar{width:8px}.progress-logs::-webkit-scrollbar-track{background:#2d2d2d;border-radius:4px}.progress-logs::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}.progress-logs::-webkit-scrollbar-thumb:hover{background:#5a5a5a}.selected-row{background-color:#e3f2fd!important}.selected-row:hover{background-color:#bbdefb!important}.selected-count{color:#06c;font-weight:600;margin-left:8px}.btn-delete-selected{padding:10px 20px;background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;margin-right:10px;transition:all .3s ease;box-shadow:0 4px 6px #dc35454d}.btn-delete-selected:hover{transform:translateY(-2px);box-shadow:0 6px 12px #dc354566;background:linear-gradient(135deg,#c82333,#bd2130)}.btn-delete-selected:active{transform:translateY(0)}.print-only-header{display:none}@media print{.print-only-header{display:block;margin-bottom:30px;padding-bottom:20px;border-bottom:3px solid #333}.print-only-header h1{font-size:24px;margin:0 0 15px;color:#333}.print-filters{background:#f8f9fa;padding:15px;border-radius:8px;border:1px solid #dee2e6}.print-filters p{margin:8px 0;font-size:13px;color:#333}.print-filters strong{color:#06c;margin-right:8px}.reports-header,.filters-section,.export-buttons,.btn-delete,.btn-delete-selected,.tabs-container,.filter-info,.page-header,.sidebar,.modal-overlay{display:none!important}.data-table th:first-child,.data-table td:first-child{display:none}.table-container{box-shadow:none;padding:0;margin:0}.data-table{font-size:9px;width:100%}.data-table th,.data-table td{padding:6px 8px;border:1px solid #dee2e6}.data-table thead{background:#f8f9fa!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.data-table tbody tr:hover,.selected-row{background-color:transparent!important}.data-table tr{page-break-inside:avoid}.data-table thead{display:table-header-group}.reports-container{padding:20px;margin:0!important;background:#fff}.badge{border:1px solid #333;-webkit-print-color-adjust:exact;print-color-adjust:exact}}.filters-section{background:#fff;border-radius:12px;padding:25px;margin-bottom:25px;box-shadow:0 2px 8px #00000014}.filters-section h3{margin:0 0 20px;color:#333;font-size:18px}.filters-grid{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:20px;align-items:end}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{font-weight:600;color:#555;font-size:14px}.filter-input{padding:10px 14px;border:2px solid #dee2e6;border-radius:8px;font-size:14px;transition:all .2s ease;font-family:inherit}.filter-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-actions{display:flex;gap:10px;flex-wrap:nowrap;align-items:flex-end}.btn-clear,.btn-expand,.btn-collapse{padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.btn-clear{background:#e9ecef;color:#495057}.btn-clear:hover{background:#dee2e6}.btn-expand{background:#4dabf7;color:#fff}.btn-expand:hover{background:#339af0}.btn-collapse{background:#868e96;color:#fff}.btn-collapse:hover{background:#6c757d}.summary-statistics{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;padding:25px;margin-bottom:25px;box-shadow:0 4px 12px #667eea4d}.summary-statistics h3{margin:0 0 20px;font-size:18px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat-card{background:#ffffff26;padding:20px;border-radius:10px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;gap:15px}.stat-icon{font-size:36px;line-height:1}.stat-content{flex:1}.stat-label{font-size:13px;opacity:.9;margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:28px;font-weight:700}.schedule-section{margin-bottom:30px}.schedule-section>h3{color:#333;font-size:20px;margin-bottom:20px}.entity-schedule-card{background:#fff;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s ease}.entity-schedule-card:hover{box-shadow:0 4px 16px #0000001f}.entity-header{padding:20px 25px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #dee2e6;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s ease}.entity-header:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6)}.entity-header-left{display:flex;align-items:center;gap:15px}.expand-icon{font-size:16px;color:#667eea;font-weight:700;width:20px;text-align:center}.entity-info h4{margin:0;font-size:18px;color:#333}.entity-code{font-size:13px;color:#666;font-weight:500}.entity-header-right{display:flex;gap:25px;align-items:center}.entity-stat{display:flex;flex-direction:column;align-items:flex-end}.entity-stat .label{font-size:12px;color:#666;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.entity-stat .value{font-size:16px;color:#333;font-weight:700}.entity-tasks{padding:20px;background:#f8f9fa}.tasks-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.tasks-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.tasks-table th{padding:12px 15px;text-align:left;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.tasks-table tbody tr{border-bottom:1px solid #e9ecef;transition:background .2s ease}.tasks-table tbody tr:hover{background:#f8f9fa}.tasks-table tbody tr.completed-task{background:#f0f9f4;opacity:.9}.tasks-table td{padding:12px 15px;font-size:14px;color:#333}.task-description{line-height:1.5}.task-comments{font-size:12px;color:#666;font-style:italic;margin-top:4px;padding:4px 8px;background:#f8f9fa;border-radius:4px;display:inline-block}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge.completed{background:#d3f9d8;color:#2b8a3e}.status-badge.pending{background:#fff3bf;color:#e67700}.no-tasks{padding:30px;text-align:center;color:#666;font-style:italic}.no-data{background:#fff;border-radius:12px;padding:50px;text-align:center;color:#666}.no-data p{font-size:16px;margin:0}.btn-export-excel,.btn-export-pdf{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-export-excel{background:linear-gradient(135deg,#37b24d,#2f9e44);color:#fff}.btn-export-excel:hover{transform:translateY(-2px);box-shadow:0 6px 20px #37b24d66}.btn-export-pdf{background:linear-gradient(135deg,#fa5252,#e03131);color:#fff}.btn-export-pdf:hover{transform:translateY(-2px);box-shadow:0 6px 20px #fa525266}.print-only{display:none}.active-filters-print{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.active-filters-print h4{margin:0 0 10px;font-size:16px;color:#495057}.filter-summary{display:flex;flex-wrap:wrap;gap:15px}.filter-item{font-size:14px;color:#495057}.filter-item strong{color:#212529;margin-right:5px}.print-header{padding:20px 0;border-bottom:3px solid #339af0;margin-bottom:20px}.print-header-content{display:flex;justify-content:space-between;align-items:center}.print-header-left h1{margin:0 0 5px;font-size:28px;color:#212529}.print-subtitle{margin:0 0 8px;font-size:14px;color:#666}.print-date{margin:0;font-size:12px;color:#868e96;font-style:italic}.print-header-right{flex-shrink:0}.print-logo{height:80px;width:auto;object-fit:contain}@media print{@page{margin:.75in .5in;@bottom-right{content:"Page " counter(page) " of " counter(pages);font-size:10px;color:#666}}body{counter-reset:page}.content-wrapper:after{content:"Page " counter(page);counter-increment:page;position:fixed;bottom:10px;right:10px;font-size:10px;color:#666}.no-print,.filters-section{display:none!important}.print-only{display:block!important}.sidebar,.nav-sidebar{display:none!important}.main-content{margin-left:0!important;width:100%!important}.content-header,.header-actions{display:none!important}.entity-schedule-card{page-break-inside:avoid;box-shadow:none;border:1px solid #dee2e6}.entity-tasks{background:#fff}.tasks-table{font-size:10px}.tasks-table th,.tasks-table td{padding:6px 8px}.summary-statistics{background:#fff;color:#333;border:1px solid #dee2e6}.stat-card{background:#f8f9fa;border:1px solid #dee2e6}.stat-label,.stat-value{color:#333}}@media (max-width: 1200px){.entity-header{flex-direction:column;align-items:flex-start;gap:15px}.entity-header-right{width:100%;justify-content:space-between}}@media (max-width: 768px){.filters-grid,.stats-grid{grid-template-columns:1fr}.entity-header-right{flex-direction:column;align-items:flex-start;gap:10px}.entity-stat{flex-direction:row;gap:10px;align-items:center}.tasks-table{font-size:12px}.tasks-table th,.tasks-table td{padding:8px 10px}}.dashboard-layout{display:flex;min-height:100vh;background:#f5f7fa}.dashboard-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.loading,.error-message{text-align:center;padding:40px;font-size:18px;color:#fff}.sidebar{background:linear-gradient(180deg,#1e3a5f,#0d1f3c);color:#fff;transition:width .3s ease;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:1000;box-shadow:2px 0 10px #0000001a}.sidebar.open{width:260px}.sidebar.closed{width:70px}.sidebar-header{padding:20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{font-size:22px;font-weight:700;white-space:nowrap}.sidebar.closed .sidebar-header h2{display:none}.sidebar-toggle{background:#fff3;border:none;color:#fff;width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:16px;transition:all .3s ease}.sidebar-toggle:hover{background:#ffffff4d}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.sidebar-nav ul{list-style:none}.nav-item{margin:4px 10px}.nav-item a{display:flex;align-items:center;padding:12px 15px;color:#fffc;text-decoration:none;border-radius:8px;transition:all .3s ease;gap:12px}.nav-item a:hover{background:#ffffff26;color:#fff}.nav-item.active a{background:#fff3;color:#fff;font-weight:600}.nav-icon{font-size:20px;min-width:24px;text-align:center}.sidebar.closed .nav-text{display:none}.sidebar-footer{border-top:1px solid rgba(255,255,255,.1);padding:15px}.user-profile{display:flex;align-items:center;gap:12px;padding:10px;margin-bottom:10px}.user-avatar{width:40px;height:40px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.sidebar.closed .user-details{display:none}.user-details{flex:1;min-width:0}.user-name{font-size:14px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:12px;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn-sidebar{width:100%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.logout-btn-sidebar:hover{background:#fff3}.main-content{transition:margin-left .3s ease;flex:1;min-height:100vh;margin-left:0;padding:0}.main-content.sidebar-open{margin-left:260px}.main-content.sidebar-closed{margin-left:70px}.content-header{background:#fff;padding:20px 30px;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;align-items:center}.content-header h1{font-size:28px;color:#333;margin:0}.header-actions{display:flex;align-items:center;gap:20px}.welcome-text{color:#666;font-size:14px}.content-body{padding:30px}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:40px}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px #00000012;display:flex;gap:20px;align-items:center;transition:transform .3s ease,box-shadow .3s ease}.card:hover{transform:translateY(-5px);box-shadow:0 8px 15px #0000001f}.card-icon{font-size:48px;line-height:1}.card-content{flex:1}.card-content h3{margin:0 0 8px;font-size:14px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.card-value{margin:0;font-size:36px;font-weight:700;line-height:1.2;color:#333}.card-label{font-size:12px;color:#999}.card-primary{border-left:4px solid #667eea}.card-success{border-left:4px solid #51cf66}.card-info{border-left:4px solid #4dabf7}.card-secondary{border-left:4px solid #1c7ed6}.card-warning{border-left:4px solid #ffa94d}.card-danger{border-left:4px solid #ff6b6b}.card-success-alt{border-left:4px solid #20c997}.entities-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #00000012}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.entities-section h2{margin:0;font-size:24px;color:#333}.header-buttons{display:flex;gap:10px;align-items:center}.clear-filters-btn{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.clear-filters-btn:hover{background:#764ba2;transform:translateY(-1px)}.btn-export-excel{background:linear-gradient(135deg,#51cf66,#40c057);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-export-excel:hover{transform:translateY(-2px);box-shadow:0 4px 12px #51cf664d}.btn-export-pdf{background:linear-gradient(135deg,#ff8c42,#ff7a24);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.btn-export-pdf:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff7c244d}.table-container{overflow-x:auto}.entities-table{width:100%;border-collapse:collapse;font-size:14px}.entities-table thead{background:#f8f9fa}.entities-table th{padding:12px 16px;text-align:left;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6}.entities-table th[style*="cursor: pointer"]{-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.entities-table th[style*="cursor: pointer"]:hover{background-color:#e9ecef}.entities-table td{padding:12px 16px;border-bottom:1px solid #e9ecef;color:#495057}.entities-table tbody tr{transition:background-color .2s ease}.entities-table tbody tr:hover{background-color:#f8f9fa}.filter-row{background:#f8f9fa}.filter-row th{padding:8px}.filter-input,.filter-select{width:100%;padding:6px 10px;border:1px solid #ced4da;border-radius:4px;font-size:13px;background:#fff;transition:border-color .2s ease}.filter-input:focus,.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.filter-input::placeholder{color:#adb5bd;font-style:italic}.filter-select{cursor:pointer}.status-filter-section{display:flex;align-items:center;gap:15px;padding:12px 8px}.status-filter-container{display:flex;flex-wrap:wrap;gap:25px;align-items:center}.status-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;padding:8px 16px;border-radius:4px;background:#fff;border:1px solid #dee2e6;transition:all .2s ease;white-space:nowrap;min-width:fit-content}.status-checkbox:hover{background-color:#f0f0f0;border-color:#667eea}.status-checkbox input[type=checkbox]{cursor:pointer;width:16px;height:16px;border-radius:3px;border:1px solid #ced4da;accent-color:#667eea}.status-clear-btn{padding:6px 12px;font-size:12px;background:#dc3545;color:#fff;border:none;border-radius:3px;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.status-clear-btn:hover{background:#c82333}.no-results{text-align:center;padding:40px 20px;color:#6c757d;font-style:italic}.text-center{text-align:center}@media (max-width: 768px){.main-content.sidebar-open,.main-content.sidebar-closed{margin-left:0}.sidebar{position:fixed;z-index:1000}.sidebar.closed{transform:translate(-100%)}.cards-grid{grid-template-columns:1fr}.content-header{flex-direction:column;align-items:flex-start;gap:10px}.entities-table{font-size:12px}.entities-table th,.entities-table td{padding:8px 12px}}@media (max-width: 900px){.main-content.sidebar-open{margin-left:70px}}.clickable-row{cursor:pointer;transition:all .2s ease}.clickable-row:hover{background-color:#e3f2fd!important;transform:scale(1.01);box-shadow:0 2px 8px #667eea33}.blocked-days-table{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.blocked-days-table table{width:100%;border-collapse:collapse}.blocked-days-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.blocked-days-table th{padding:16px;text-align:left;font-weight:600;font-size:14px}.blocked-days-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s ease}.blocked-days-table tbody tr:hover{background-color:#f8f9fa}.blocked-days-table td{padding:14px 16px;font-size:14px;color:#495057}.blocked-days-table .text-center{text-align:center}.blocked-days-table .no-data{text-align:center;padding:40px;color:#868e96;font-style:italic}.badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.badge.recurring{background:#e7f5ff;color:#1971c2}.badge.one-time{background:#fff3bf;color:#e67700}.badge.active{background:#d3f9d8;color:#2f9e44}.badge.inactive{background:#ffe0e0;color:#c92a2a}.actions{display:flex;gap:8px;justify-content:center}.btn-edit,.btn-delete{background:none;border:none;cursor:pointer;font-size:18px;padding:6px;border-radius:6px;transition:all .2s ease}.btn-edit:hover{background:#e7f5ff;transform:scale(1.1)}.btn-delete:hover{background:#ffe0e0;transform:scale(1.1)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:24px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:22px;color:#212529}.modal-close{background:none;border:none;font-size:32px;color:#868e96;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-close:hover{background:#f1f3f5;color:#495057}.modal-body{padding:24px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#495057;font-size:14px}.form-input{width:100%;padding:10px 14px;border:1px solid #ced4da;border-radius:8px;font-size:14px;transition:all .2s ease}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.checkbox-group label{display:flex;flex-direction:column;gap:4px}.checkbox-group input[type=checkbox]{width:auto;margin-right:8px}.checkbox-group span{display:inline-block;font-weight:600}.checkbox-group small{color:#868e96;font-size:12px;margin-left:28px;font-weight:400}.modal-footer{padding:20px 24px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;gap:12px}.btn-cancel{padding:10px 20px;border:1px solid #ced4da;background:#fff;color:#495057;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background:#f8f9fa;border-color:#adb5bd}.btn-save{padding:10px 20px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-save:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media (max-width: 768px){.blocked-days-table{overflow-x:auto}.modal-content{width:95%;max-width:none}}.configuration-container{padding:20px;max-width:1000px;margin:0 auto}.configuration-loading{padding:40px;text-align:center;font-size:18px;color:#666}.configuration-header{margin-bottom:30px;border-bottom:2px solid #007bff;padding-bottom:15px}.configuration-header h2{margin:0 0 10px;color:#333;font-size:28px}.configuration-header p{margin:0;color:#666;font-size:14px}.configuration-content{display:flex;flex-direction:column;gap:30px}.config-section{background:#fff;border:1px solid #ddd;border-radius:8px;padding:25px;box-shadow:0 2px 4px #0000000d}.config-section h3{margin:0 0 15px;color:#333;font-size:20px}.config-description{margin:0 0 20px;color:#666;line-height:1.6}.config-description strong{color:#d9534f}.config-field{margin-bottom:25px}.config-field label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.config-input,.config-select{width:100%;padding:10px 15px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff;transition:border-color .3s}.config-input{font-family:Consolas,Monaco,monospace}.config-input:hover,.config-select:hover{border-color:#007bff}.config-input:focus,.config-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.field-hint{display:block;margin-top:5px;color:#666;font-size:12px;font-style:italic}.config-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:15px;margin-bottom:20px}.info-item{display:flex;align-items:center;gap:10px;color:#333;font-size:14px}.server-badge{background:#007bff;color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}.config-message{padding:12px 15px;border-radius:4px;margin-bottom:20px;font-size:14px}.config-message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.config-message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.config-actions{display:flex;gap:15px}.btn-primary,.btn-secondary{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.btn-secondary:hover{background-color:#5a6268}.config-notes{margin:0;padding-left:20px;color:#666;line-height:1.8}.config-notes li{margin-bottom:8px}.config-notes strong{color:#333}.config-notes code{background:#f4f4f4;padding:2px 6px;border-radius:3px;font-family:Consolas,Monaco,monospace;font-size:12px}.config-presets{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px;margin-top:15px}.preset-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:15px;transition:all .3s}.preset-card:hover{border-color:#007bff;box-shadow:0 4px 8px #007bff1a;transform:translateY(-2px)}.preset-card h4{margin:0 0 10px;color:#333;font-size:16px}.preset-card p{margin:5px 0;font-size:13px;color:#555}.preset-card p strong{color:#333;min-width:80px;display:inline-block}.preset-desc{margin-top:10px;padding-top:10px;border-top:1px solid #dee2e6;color:#666!important;font-style:italic}.xml-config-container{padding:20px;max-width:800px;margin:0 auto}.xml-config-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.xml-config-card .card-header{background:linear-gradient(135deg,#0047ab,#06c);color:#fff;padding:20px 30px;border-bottom:3px solid #003d8f}.xml-config-card .card-header h2{margin:0 0 8px;font-size:24px;font-weight:600}.xml-config-card .card-header p{margin:0;font-size:14px;opacity:.9}.xml-config-card .card-body{padding:30px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:8px;color:#333;font-size:14px}.form-input{width:100%;padding:10px 12px;border:2px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .3s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#0047ab}.form-input:disabled{background-color:#f5f5f5;cursor:not-allowed;color:#666}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:45px}.password-toggle{position:absolute;right:10px;background:none;border:none;font-size:20px;cursor:pointer;padding:5px;opacity:.6;transition:opacity .3s}.password-toggle:hover{opacity:1}.button-group{display:flex;gap:10px;margin-top:30px;flex-wrap:wrap}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:8px}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background-color:#0047ab;color:#fff}.btn-primary:hover:not(:disabled){background-color:#003d8f}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover:not(:disabled){background-color:#218838}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover:not(:disabled){background-color:#138496}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.message{padding:12px 16px;border-radius:4px;margin-bottom:20px;font-size:14px;font-weight:500}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 768px){.xml-config-container{padding:10px}.xml-config-card .card-header{padding:15px 20px}.xml-config-card .card-body{padding:20px}.button-group{flex-direction:column}.btn{width:100%;justify-content:center}}.multiple-payslips-container{padding:20px;transition:margin-left .3s ease;margin-left:260px;min-height:100vh;background:#f5f7fa}.multiple-payslips-container.sidebar-collapsed{margin-left:70px}.data-table{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.table-header{background:linear-gradient(135deg,#0047ab,#06c);color:#fff;padding:20px 30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;border-bottom:3px solid #003d8f}.table-header h2{margin:0;font-size:24px;font-weight:600}.header-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:5px}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-excel{background-color:#217346;color:#fff}.btn-excel:hover{background-color:#1a5c37}.btn-pdf{background-color:#d32f2f;color:#fff}.btn-pdf:hover{background-color:#b71c1c}.btn-print{background-color:#455a64;color:#fff}.btn-print:hover{background-color:#37474f}.btn-refresh{background-color:#0047ab;color:#fff}.btn-refresh:hover{background-color:#003d8f}.filters-section{padding:20px 30px;background-color:#f5f5f5;border-bottom:2px solid #0047ab;display:flex;gap:20px;flex-wrap:wrap;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:5px;min-width:200px}.filter-group label{font-weight:600;font-size:14px;color:#333}.filter-input,.filter-select{padding:8px 12px;border:2px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .3s}.filter-input:focus,.filter-select:focus{outline:none;border-color:#0047ab}.filter-summary{margin-left:auto;font-weight:600;color:#0047ab;padding:8px 0;font-size:14px}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}thead{background-color:#0047ab;color:#fff;position:sticky;top:0;z-index:10}th{padding:12px 15px;text-align:left;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;border-right:1px solid rgba(255,255,255,.1)}th:last-child{border-right:none}th:hover{background-color:#003d8f}tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s}tbody tr:nth-child(2n){background-color:#e3f2fd}tbody tr:hover{background-color:#bbdefb}td{padding:12px 15px;color:#333;font-size:14px}.payslip-count-badge{display:inline-block;padding:4px 12px;background-color:#ff9800;color:#fff;border-radius:12px;font-weight:600;font-size:13px}.no-data{text-align:center;padding:40px;color:#999;font-style:italic}.loading,.error{padding:40px;text-align:center;font-size:18px}.loading{color:#0047ab}.error{color:#d32f2f;background-color:#ffebee;border-radius:4px;margin:20px}@media (max-width: 768px){.multiple-payslips-container{padding:10px;margin-left:0!important}.table-header{padding:15px;flex-direction:column;align-items:flex-start}.header-actions{width:100%}.btn{flex:1;justify-content:center}.filters-section{padding:15px;flex-direction:column}.filter-group{width:100%}.filter-summary{margin-left:0}th,td{padding:8px 10px;font-size:12px}.table-wrapper{overflow-x:scroll}table{min-width:600px}}.change-orders-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:#fff;border-radius:10px;padding:16px;text-align:center;box-shadow:0 2px 8px #0000000f;border-left:4px solid #667eea;transition:transform .15s ease,box-shadow .15s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card.bug-fix{border-left-color:#dc3545}.stat-card.change-order{border-left-color:#667eea}.stat-card.new-co{border-left-color:#28a745}.stat-card.open{border-left-color:#17a2b8}.stat-card.in-progress{border-left-color:#667eea}.stat-card.testing{border-left-color:#fd7e14}.stat-card.resolved{border-left-color:#28a745}.stat-card.closed{border-left-color:#6c757d}.stat-card.deferred{border-left-color:#ffc107}.stat-card .stat-value{font-size:28px;font-weight:800;color:#333;line-height:1}.stat-card .stat-label{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-top:6px}.score-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-weight:700;font-size:13px;color:#fff}.score-badge.score-5{background:#dc3545}.score-badge.score-4{background:#fd7e14}.score-badge.score-3{background:#ffc107;color:#333}.score-badge.score-2{background:#17a2b8}.score-badge.score-1{background:#6c757d}.combined-score{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:26px;border-radius:13px;font-weight:700;font-size:13px;padding:0 10px}.combined-score.high{background:#f8d7da;color:#721c24}.combined-score.medium{background:#fff3cd;color:#856404}.combined-score.low{background:#d4edda;color:#155724}.category-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.category-badge.bug-fix{background:#f8d7da;color:#721c24}.category-badge.change-order{background:#d6e4ff;color:#1a3a6c}.category-badge.new-change-order{background:#d4edda;color:#155724}.co-status-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;white-space:nowrap}.co-status-badge.status-open{background:#17a2b8;color:#fff}.co-status-badge.status-in-progress{background:#667eea;color:#fff}.co-status-badge.status-testing{background:#fd7e14;color:#fff}.co-status-badge.status-resolved{background:#28a745;color:#fff}.co-status-badge.status-closed{background:#6c757d;color:#fff}.co-status-badge.status-deferred{background:#ffc107;color:#333}.co-description-cell{max-width:350px}.co-description-cell .co-title{font-weight:600;color:#333;font-size:13px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;cursor:pointer}.co-description-cell .co-title:hover{color:#667eea}.co-ref-nums{display:flex;gap:6px;margin-top:3px;flex-wrap:wrap}.co-ref-tag{font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;background:#f0f0f0;color:#666}.module-tag{display:inline-block;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;background:#e8eaf6;color:#3949ab;white-space:nowrap}.co-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.co-detail-modal{background:#fff;border-radius:14px;padding:0;width:95%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;color:#333;box-shadow:0 20px 60px #00000026}.co-detail-header{padding:24px 30px 16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.co-detail-header h2{margin:0;font-size:20px;color:#333;line-height:1.4;flex:1}.co-detail-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;line-height:1;flex-shrink:0}.co-detail-close:hover{color:#333}.co-detail-body{padding:20px 30px 30px;overflow-y:auto;flex:1}.co-detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:10px}.co-detail-meta-item{display:flex;flex-direction:column;gap:4px}.co-detail-meta-item .meta-label{font-size:11px;font-weight:700;text-transform:uppercase;color:#888;letter-spacing:.5px}.co-detail-meta-item .meta-value{font-size:14px;font-weight:600;color:#333}.co-detail-section{margin-bottom:20px}.co-detail-section h3{font-size:14px;font-weight:700;text-transform:uppercase;color:#667eea;letter-spacing:.5px;margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid #f0f0f0}.co-detail-section .detail-text{font-size:14px;color:#444;line-height:1.7;white-space:pre-wrap;word-break:break-word;background:#fafafa;padding:14px 18px;border-radius:8px;border:1px solid #eee}.co-detail-scores{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.co-detail-score-item{text-align:center;padding:12px;background:#f8f9fa;border-radius:8px}.co-detail-score-item .score-label{font-size:11px;font-weight:700;text-transform:uppercase;color:#888;margin-bottom:6px}.co-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.co-form-modal{background:#fff;border-radius:14px;padding:30px;width:95%;max-width:850px;max-height:90vh;overflow-y:auto;color:#333;box-shadow:0 20px 60px #00000026}.co-form-modal h2{margin:0 0 24px;font-size:20px;color:#333}.co-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.co-form-grid .full-width{grid-column:1 / -1}.co-form-grid .half-width{grid-column:span 2}.co-form-group{display:flex;flex-direction:column;gap:5px}.co-form-group label{font-size:13px;font-weight:600;color:#333}.co-form-group input,.co-form-group select,.co-form-group textarea{padding:9px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;color:#333;transition:border-color .15s}.co-form-group input:focus,.co-form-group select:focus,.co-form-group textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.co-form-group textarea{resize:vertical;min-height:80px}.co-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:16px;border-top:1px solid #eee}.import-preview-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:12px}.import-preview-table th{background:#f8f9fa;padding:8px 10px;text-align:left;font-weight:700;color:#555;border-bottom:2px solid #dee2e6;white-space:nowrap}.import-preview-table td{padding:6px 10px;border-bottom:1px solid #f0f0f0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-preview-table tr:hover td{background:#f8f9fa}.co-table-wrapper{overflow-x:auto;margin:0 -5px;padding:0 5px}.co-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.co-table thead th{background:#f8f9fa;padding:12px 10px;text-align:left;font-weight:700;font-size:12px;color:#555;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid #dee2e6;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;position:sticky;top:0;z-index:1}.co-table thead th:hover{background:#e9ecef}.co-table tbody td{padding:10px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.co-table tbody tr:hover td{background:#f5f7ff}.co-table .actions-cell{white-space:nowrap}.co-table .actions-cell button{padding:4px 10px;border:none;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;margin-right:4px}.co-table .btn-edit{background:#667eea;color:#fff}.co-table .btn-edit:hover{background:#5a6fd6}.co-table .btn-delete{background:#dc3545;color:#fff}.co-table .btn-delete:hover{background:#c82333}.co-filter-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}.co-btn{padding:9px 20px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s,transform .1s;white-space:nowrap}.co-btn:hover{transform:translateY(-1px)}.co-btn:active{transform:translateY(0)}.co-btn-primary{background:#667eea;color:#fff}.co-btn-primary:hover{background:#5a6fd6}.co-btn-secondary{background:#6c757d;color:#fff}.co-btn-secondary:hover{background:#5a6268}.co-btn-success{background:#28a745;color:#fff}.co-btn-success:hover{background:#218838}.co-btn-info{background:#17a2b8;color:#fff}.co-btn-info:hover{background:#138496}.co-btn-warning{background:#fd7e14;color:#fff}.co-btn-warning:hover{background:#e8690b}.co-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.change-orders-stats{grid-template-columns:repeat(3,1fr)}.co-form-grid{grid-template-columns:1fr}.co-form-grid .half-width,.co-form-grid .full-width{grid-column:1}}.test-cases-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:20px}.tc-stat-card{background:#fff;border-radius:10px;padding:16px;text-align:center;box-shadow:0 2px 8px #0000000f;border-left:4px solid #667eea;transition:transform .15s ease,box-shadow .15s ease}.tc-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.tc-stat-card.total{border-left-color:#667eea}.tc-stat-card.pass{border-left-color:#28a745}.tc-stat-card.fail{border-left-color:#dc3545}.tc-stat-card.pending{border-left-color:#ffc107}.tc-stat-card.blocked{border-left-color:#6c757d}.tc-stat-card.retest{border-left-color:#fd7e14}.tc-stat-card.linked{border-left-color:#17a2b8}.tc-stat-card.versions{border-left-color:#6f42c1}.tc-stat-card .tc-stat-value{font-size:28px;font-weight:800;color:#333;line-height:1}.tc-stat-card .tc-stat-label{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-top:6px}.tc-result-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.tc-result-badge.result-pass{background:#d4edda;color:#155724}.tc-result-badge.result-fail{background:#f8d7da;color:#721c24}.tc-result-badge.result-pending{background:#fff3cd;color:#856404}.tc-result-badge.result-blocked{background:#e2e3e5;color:#383d41}.tc-result-badge.result-retest{background:#ffe0cc;color:#8a4500}.tc-version-tag{display:inline-block;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:700;background:#e8eaf6;color:#3949ab;font-family:Consolas,Monaco,monospace;white-space:nowrap}.tc-type-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.tc-type-badge.type-patch{background:#d6e4ff;color:#1a3a6c}.tc-type-badge.type-hotfix{background:#f8d7da;color:#721c24}.tc-type-badge.type-release{background:#d4edda;color:#155724}.tc-type-badge.type-enhancement{background:#e0cffc;color:#4a1a8a}.tc-type-badge.type-configuration{background:#fff3cd;color:#856404}.tc-co-link{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;background:#e3f2fd;color:#1565c0;cursor:pointer;transition:background .15s;white-space:nowrap}.tc-co-link:hover{background:#bbdefb}.tc-co-unlinked{font-size:11px;color:#999;font-style:italic}.tc-testers{display:flex;flex-direction:column;gap:2px}.tc-tester-name{font-size:11px;color:#555;white-space:nowrap}.tc-tester-name .tester-label{font-weight:700;color:#888;margin-right:3px}.tc-description-cell{max-width:320px}.tc-description-cell .tc-title{font-weight:600;color:#333;font-size:13px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;cursor:pointer}.tc-description-cell .tc-title:hover{color:#667eea}.tc-table-wrapper{overflow-x:auto;margin:0 -5px;padding:0 5px}.tc-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.tc-table thead th{background:#f8f9fa;padding:12px 10px;text-align:left;font-weight:700;font-size:12px;color:#555;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid #dee2e6;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;position:sticky;top:0;z-index:1}.tc-table thead th:hover{background:#e9ecef}.tc-table tbody td{padding:10px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.tc-table tbody tr:hover td{background:#f5f7ff}.tc-table .actions-cell{white-space:nowrap}.tc-table .actions-cell button{padding:4px 10px;border:none;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;margin-right:4px}.tc-table .btn-view{background:#667eea;color:#fff}.tc-table .btn-view:hover{background:#5a6fd6}.tc-table .btn-edit{background:#17a2b8;color:#fff}.tc-table .btn-edit:hover{background:#138496}.tc-table .btn-delete{background:#dc3545;color:#fff}.tc-table .btn-delete:hover{background:#c82333}.tc-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.tc-detail-modal{background:#fff;border-radius:14px;padding:0;width:95%;max-width:950px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;color:#333;box-shadow:0 20px 60px #00000026}.tc-detail-header{padding:24px 30px 16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.tc-detail-header h2{margin:0;font-size:20px;color:#333;line-height:1.4;flex:1}.tc-detail-close{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;line-height:1;flex-shrink:0}.tc-detail-close:hover{color:#333}.tc-detail-body{padding:20px 30px 30px;overflow-y:auto;flex:1}.tc-detail-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:10px}.tc-detail-meta-item{display:flex;flex-direction:column;gap:4px}.tc-detail-meta-item .meta-label{font-size:11px;font-weight:700;text-transform:uppercase;color:#888;letter-spacing:.5px}.tc-detail-meta-item .meta-value{font-size:14px;font-weight:600;color:#333}.tc-detail-section{margin-bottom:20px}.tc-detail-section h3{font-size:14px;font-weight:700;text-transform:uppercase;color:#667eea;letter-spacing:.5px;margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid #f0f0f0}.tc-detail-section .detail-text{font-size:14px;color:#444;line-height:1.7;white-space:pre-wrap;word-break:break-word;background:#fafafa;padding:14px 18px;border-radius:8px;border:1px solid #eee}.tc-linked-co-card{background:#f0f7ff;border:1px solid #c2deff;border-radius:10px;padding:16px 20px;margin-bottom:20px}.tc-linked-co-card h4{margin:0 0 8px;font-size:13px;font-weight:700;text-transform:uppercase;color:#1565c0;letter-spacing:.5px}.tc-linked-co-card .co-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.tc-linked-co-card .co-info-item{display:flex;flex-direction:column;gap:2px}.tc-linked-co-card .co-info-label{font-size:10px;font-weight:700;text-transform:uppercase;color:#7aa5d6}.tc-linked-co-card .co-info-value{font-size:13px;font-weight:600;color:#333}.tc-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.tc-form-modal{background:#fff;border-radius:14px;padding:30px;width:95%;max-width:900px;max-height:90vh;overflow-y:auto;color:#333;box-shadow:0 20px 60px #00000026}.tc-form-modal h2{margin:0 0 24px;font-size:20px;color:#333}.tc-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.tc-form-grid .full-width{grid-column:1 / -1}.tc-form-grid .half-width{grid-column:span 2}.tc-form-group{display:flex;flex-direction:column;gap:5px}.tc-form-group label{font-size:13px;font-weight:600;color:#333}.tc-form-group input,.tc-form-group select,.tc-form-group textarea{padding:9px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;color:#333;transition:border-color .15s}.tc-form-group input:focus,.tc-form-group select:focus,.tc-form-group textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.tc-form-group textarea{resize:vertical;min-height:80px}.tc-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:16px;border-top:1px solid #eee}.tc-filter-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}.tc-import-preview-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:12px}.tc-import-preview-table th{background:#f8f9fa;padding:8px 10px;text-align:left;font-weight:700;color:#555;border-bottom:2px solid #dee2e6;white-space:nowrap}.tc-import-preview-table td{padding:6px 10px;border-bottom:1px solid #f0f0f0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tc-import-preview-table tr:hover td{background:#f8f9fa}@media (max-width: 768px){.test-cases-stats{grid-template-columns:repeat(3,1fr)}.tc-form-grid{grid-template-columns:1fr}.tc-form-grid .half-width,.tc-form-grid .full-width{grid-column:1}}.da-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}.da-stat-card{background:#fff;border-radius:10px;padding:16px;text-align:center;box-shadow:0 2px 8px #0000000f;border-left:4px solid #667eea;transition:transform .15s ease,box-shadow .15s ease}.da-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.da-stat-card.total{border-left-color:#667eea}.da-stat-card.dup-records{border-left-color:#fd7e14}.da-stat-card.dup-groups{border-left-color:#dc3545}.da-stat-card.recent-dups{border-left-color:#b71c1c}.da-stat-card .da-stat-value{font-size:32px;font-weight:800;color:#333;line-height:1}.da-stat-card.dup-records .da-stat-value{color:#fd7e14}.da-stat-card.dup-groups .da-stat-value{color:#dc3545}.da-stat-card.recent-dups .da-stat-value{color:#b71c1c}.da-stat-card .da-stat-label{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-top:6px}.da-flag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;white-space:nowrap}.da-flag.recent-dup{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.da-flag.dup{background:#ffe0cc;color:#8a4500;border:1px solid #ffc08a}.da-flag.clear{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.da-table-wrapper{overflow-x:auto;margin:0 -5px;padding:0 5px}.da-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.da-table thead th{background:#f8f9fa;padding:12px 10px;text-align:left;font-weight:700;font-size:12px;color:#555;text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid #dee2e6;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;position:sticky;top:0;z-index:1}.da-table thead th:hover{background:#e9ecef}.da-table tbody td{padding:10px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.da-table tbody tr.row-recent-dup td{background:#fff5f5}.da-table tbody tr.row-recent-dup:hover td{background:#fde8e8}.da-table tbody tr.row-dup td{background:#fff8f2}.da-table tbody tr.row-dup:hover td{background:#fef0e0}.da-table tbody tr.row-normal:hover td{background:#f5f7ff}.da-table tbody tr.row-recent-dup td:first-child{border-left:3px solid #dc3545}.da-table tbody tr.row-dup td:first-child{border-left:3px solid #fd7e14}.da-amount{font-weight:700;color:#333;font-variant-numeric:tabular-nums;white-space:nowrap}.da-employee{display:flex;flex-direction:column;gap:2px}.da-employee .da-trn{font-size:11px;color:#888;font-family:Consolas,monospace}.da-employee .da-name{font-weight:600;color:#333;font-size:13px}.da-allowance-name{font-weight:600;color:#333;max-width:200px}.da-cycle-tag{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;background:#e8eaf6;color:#3949ab;white-space:nowrap;font-family:Consolas,monospace}.da-group-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:11px;font-size:11px;font-weight:700;margin-left:6px;background:#dc3545;color:#fff;padding:0 5px}.da-filter-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;margin-top:14px}.da-toggle-wrap{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:6px;background:#f8f9fa;border:1px solid #dee2e6;cursor:pointer;font-size:13px;font-weight:600;color:#555;transition:background .15s,border-color .15s;-webkit-user-select:none;user-select:none}.da-toggle-wrap.active{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.da-toggle-wrap input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#dc3545}.da-legend{display:flex;gap:16px;flex-wrap:wrap;align-items:center;padding:10px 14px;background:#f8f9fa;border-radius:8px;margin-bottom:12px;font-size:12px}.da-legend-item{display:flex;align-items:center;gap:6px;font-weight:600;color:#555}@media (max-width: 768px){.da-stats{grid-template-columns:repeat(2,1fr)}}.ae-page{padding:24px;max-width:1400px}.ae-page h1{font-size:24px;font-weight:700;color:#1a1a2e;margin-bottom:4px}.ae-subtitle{font-size:13px;color:#888;margin-bottom:20px}.ae-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:#fff;border-radius:10px;padding:16px 20px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px}.ae-filter-group{display:flex;flex-direction:column;gap:4px;min-width:220px;flex:1}.ae-filter-group label{font-size:11px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.4px}.ae-filter-group select,.ae-filter-group input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:13px;color:#333;background:#fafafa;transition:border-color .15s ease;height:36px}.ae-filter-group select:focus,.ae-filter-group input:focus{outline:none;border-color:#667eea;background:#fff}.ae-filter-actions{display:flex;gap:8px;align-items:flex-end}.ae-btn{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;height:36px;transition:background .15s ease,transform .1s ease;white-space:nowrap}.ae-btn:active{transform:scale(.97)}.ae-btn-primary{background:#667eea;color:#fff}.ae-btn-primary:hover{background:#5a6fd6}.ae-btn-primary:disabled{background:#b0b8e8;cursor:not-allowed}.ae-btn-secondary{background:#f0f0f0;color:#444}.ae-btn-secondary:hover{background:#e0e0e0}.ae-btn-export{background:#28a745;color:#fff}.ae-btn-export:hover{background:#218838}.ae-btn-export:disabled{background:#8ecda0;cursor:not-allowed}.ae-results-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ae-count-badge{background:#667eea;color:#fff;border-radius:20px;padding:3px 12px;font-size:12px;font-weight:700}.ae-table-wrapper{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f;overflow:auto}.ae-table{width:100%;border-collapse:collapse;font-size:13px}.ae-table thead th{background:#f4f6ff;color:#444;font-weight:700;padding:12px 14px;text-align:left;border-bottom:2px solid #e5e8f5;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.ae-table thead th:hover{background:#e8ecff}.ae-table thead th .sort-arrow{margin-left:4px;color:#667eea}.ae-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .1s ease}.ae-table tbody tr:hover{background:#f8f9ff}.ae-table tbody td{padding:10px 14px;color:#333;vertical-align:middle}.ae-contrib{font-family:monospace;font-weight:600;color:#667eea}.ae-btn-trn{background:#17a2b8;color:#fff}.ae-btn-trn:hover{background:#138496}.ae-btn-trn:disabled{background:#89cdd8;cursor:not-allowed}.ae-btn-update-all{background:#fd7e14;color:#fff}.ae-btn-update-all:hover{background:#e06800}.ae-btn-update-all:disabled{background:#fdb97a;cursor:not-allowed}.ae-trn-summary{display:flex;gap:6px;align-items:center}.ae-filter-pill{padding:3px 10px;border-radius:12px;border:1px solid #ccc;background:#f0f0f0;color:#555;font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.ae-filter-pill:hover:not(:disabled){background:#e0e0e0}.ae-filter-pill.active{background:#667eea;color:#fff;border-color:#667eea}.ae-filter-pill:disabled{opacity:.45;cursor:default}.ae-filter-pill.ae-pill-warn{border-color:#e0a800;color:#856404;background:#fff8dc}.ae-filter-pill.ae-pill-warn:hover:not(:disabled){background:#fff3cd}.ae-filter-pill.ae-pill-warn.active{background:#856404;color:#fff;border-color:#856404}.ae-filter-pill.ae-pill-err{border-color:#c82333;color:#721c24;background:#fde8ea}.ae-filter-pill.ae-pill-err:hover:not(:disabled){background:#f8d7da}.ae-filter-pill.ae-pill-err.active{background:#721c24;color:#fff;border-color:#721c24}.ae-badge-ok,.ae-badge-warn,.ae-badge-err{display:inline-flex;align-items:center;gap:3px;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:700;white-space:nowrap}.ae-badge-ok{background:#d4edda;color:#155724}.ae-badge-warn{background:#fff3cd;color:#856404}.ae-badge-err{background:#f8d7da;color:#721c24}.ae-th-trn{cursor:default!important;min-width:120px}.ae-th-trn:hover{background:#f4f6ff!important}.ae-trn-cell{white-space:nowrap}.ae-btn-trn-row{padding:3px 10px;border:1px solid #17a2b8;border-radius:4px;background:transparent;color:#17a2b8;font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.ae-btn-trn-row:hover{background:#17a2b8;color:#fff}.ae-trn-badge{display:inline-flex;align-items:center;gap:4px;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:700}.ae-trn-middle{font-weight:400;font-style:italic;font-size:10px;opacity:.85}.ae-trn-checking{font-size:14px}.ae-cell-match{background:#f0fff4;color:#155724}.ae-cell-mismatch{background:#fff5f5;color:#721c24}.ae-trn-diff{font-size:11px;color:#dc3545;white-space:nowrap}.ae-trn-diff em{font-style:normal;font-weight:600}.ae-btn-trn-update{display:inline-block;margin-top:4px;padding:2px 8px;border:1px solid #fd7e14;border-radius:4px;background:transparent;color:#fd7e14;font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.ae-btn-trn-update:hover:not(:disabled){background:#fd7e14;color:#fff}.ae-btn-trn-update:disabled{opacity:.6;cursor:not-allowed}.ae-update-ok{display:inline-block;margin-top:4px;font-size:11px;font-weight:700;color:#155724}.ae-update-err{display:inline-block;margin-top:4px;font-size:11px;font-weight:700;color:#721c24;cursor:help}.ae-empty,.ae-loading,.ae-error{text-align:center;padding:60px 20px;color:#888;font-size:14px}.ae-error{color:#dc3545}.ae-spinner{width:36px;height:36px;border:4px solid #e8ecff;border-top-color:#667eea;border-radius:50%;animation:ae-spin .7s linear infinite;margin:0 auto 12px}@keyframes ae-spin{to{transform:rotate(360deg)}}.workplan-subtitle{margin:6px 0 0;color:#6b7280;font-size:14px}.workplan-header-actions{flex-wrap:wrap;justify-content:flex-end}.workplan-delete-btn{background:linear-gradient(135deg,#ef4444,#dc2626)}.workplan-message{margin-bottom:20px;padding:14px 16px;border-radius:10px;font-size:14px}.success-message.workplan-message{background:#ecfdf3;color:#166534;border:1px solid #bbf7d0}.error-message.workplan-message{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.workplan-toolbar{display:flex;justify-content:space-between;gap:20px;align-items:end;margin-bottom:20px;flex-wrap:wrap}.workplan-select-group{min-width:280px}.workplan-select-group label{display:block;margin-bottom:8px;font-size:13px;font-weight:600;color:#374151}.workplan-stats{display:flex;gap:16px;color:#6b7280;font-size:13px}.workplan-sheet{background:#f8fbff;border:1px solid #cfe0f5;border-radius:16px;box-shadow:0 10px 30px #0f172a14;overflow:hidden;padding:0}.workplan-sheet-header{text-align:center;padding:28px 20px 18px;background:linear-gradient(180deg,#eaf4ff,#f8fbff);border-bottom:1px solid #cfe0f5}.workplan-sheet-header h2,.workplan-sheet-header h3{margin:0;color:#111827;letter-spacing:.03em}.workplan-sheet-header h2{font-size:30px;font-weight:800}.workplan-sheet-header h3{margin-top:10px;font-size:22px;font-weight:700}.workplan-meta-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:0;border-bottom:1px solid #cfe0f5}.workplan-meta-grid label{display:flex;flex-direction:column;gap:8px;padding:16px;border-right:1px solid #cfe0f5;background:#eaf4ff}.workplan-meta-grid label:last-child{border-right:none}.workplan-meta-grid span{font-size:13px;font-weight:700;color:#4b5563}.workplan-meta-grid input,.workplan-meta-grid select{border:1px solid #b9d3f0;border-radius:8px;padding:10px 12px;font-size:14px;background:#fff}.workplan-table-wrap{overflow-x:auto}.workplan-table{width:100%;border-collapse:collapse;min-width:1200px}.workplan-table thead th{background:#e8f1fb;border:1px solid #202020;color:#111827;padding:12px 10px;font-size:13px;text-align:center;vertical-align:middle}.workplan-table td{border:1px solid #202020;vertical-align:top;padding:0;background:#fff}.workplan-table textarea{width:100%;min-height:132px;padding:12px;border:none;resize:vertical;font:inherit;color:#1f2937;background:transparent;line-height:1.45}.workplan-table textarea:focus{outline:2px solid #1d4ed8;outline-offset:-2px;background:#f8fbff}.workplan-actions-col{width:96px}.workplan-row-actions{min-width:96px;text-align:center;padding:12px 8px!important;background:#f2f8ff!important}.workplan-row-number{display:block;font-size:13px;font-weight:700;margin-bottom:10px;color:#374151}.workplan-row-delete{border:none;background:#fee2e2;color:#b91c1c;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600}.workplan-row-delete:disabled{opacity:.5;cursor:not-allowed}.workplan-footer-actions{padding:18px 20px 22px;display:flex;justify-content:flex-end;background:#eef6ff}.loading-card{margin-top:20px;background:#fff;border-radius:12px;padding:18px 20px;color:#6b7280;box-shadow:0 4px 6px #0000000d}@media (max-width: 900px){.workplan-meta-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}}@media (max-width: 640px){.workplan-toolbar,.workplan-header-actions,.workplan-stats{flex-direction:column;align-items:stretch}.workplan-meta-grid{grid-template-columns:1fr}}.corporate-plan-sheet .workplan-sheet-header{background:linear-gradient(180deg,#dceeff,#f5faff)}.corporate-plan-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(200px,1fr));gap:0;border-bottom:1px solid #cfe0f5}.corporate-plan-meta-grid label{display:flex;flex-direction:column;gap:8px;padding:16px;border-right:1px solid #cfe0f5;border-bottom:1px solid #cfe0f5;background:#eef6ff}.corporate-plan-meta-grid label:nth-child(3n){border-right:none}.corporate-plan-meta-grid span{font-size:13px;font-weight:700;color:#4b5563}.corporate-plan-meta-grid input,.corporate-plan-meta-grid select{border:1px solid #b9d3f0;border-radius:8px;padding:10px 12px;font-size:14px;background:#fff}.corporate-plan-table{min-width:1400px}.corporate-plan-table textarea{min-height:120px}@media (max-width: 900px){.corporate-plan-meta-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}.corporate-plan-meta-grid label:nth-child(3n){border-right:1px solid #cfe0f5}.corporate-plan-meta-grid label:nth-child(2n){border-right:none}}@media (max-width: 640px){.corporate-plan-meta-grid{grid-template-columns:1fr}.corporate-plan-meta-grid label{border-right:none}}#root{width:100%;margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
