body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.editable-table-container{background-color:#f8f9fa;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:20px}.table-header{background-color:#fff;padding:15px}.table-header h2{font-size:18px;font-weight:600}.add-btn{background-color:#5a9fd4;border-radius:4px;font-size:12px;transition:background-color .2s}.add-btn:hover{background-color:#4a8bc2}.test-btn{align-items:center;background-color:#6f42c1;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:6px;padding:8px 16px;transition:background-color .2s}.test-btn:hover{background-color:#5a359a}.reload-btn{background-color:#17a2b8;font-weight:500;gap:6px;padding:8px 16px;transition:background-color .2s}.reload-btn:hover{background-color:#138496}.reload-btn:disabled{opacity:.6}.delete-project-btn,.edit-project-btn{background-color:#a8d5a8;border:none;border-radius:4px;color:#2d5016;cursor:pointer;font-size:12px;font-weight:500;padding:8px 16px;transition:background-color .2s}.delete-project-btn{background-color:#f5c6cb;color:#721c24}.edit-project-btn:hover{background-color:#98c998}.delete-project-btn:hover{background-color:#f1b0b7}.table-wrapper{background-color:#fff;box-shadow:0 2px 8px #0000001a}.editable-table{border-collapse:collapse;color:#000;font-size:12px;min-width:1200px;width:100%}.editable-table th{background-color:#e8f4f8;border:1px solid #d1ecf1;color:#2c3e50;font-weight:600;padding:12px 8px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:10}.editable-table td{background-color:#fff;border:1px solid #dee2e6;color:#000;padding:0;position:relative}.cell-content{padding:8px;transition:background-color .2s}.cell-content:hover{background-color:#f8f9fa}.cell-text{color:#000;line-height:1.4}.edit-icon{margin-left:8px}.editing-cell{background-color:#fff3cd;border:2px solid #ffc107;padding:4px}.edit-input,.edit-textarea{background-color:initial;border:none;color:#000;font-family:inherit;font-size:12px;outline:none;padding:4px;resize:none;width:100%}.edit-textarea{max-height:80px;min-height:40px}.edit-actions{gap:4px;margin-top:4px}.cancel-btn,.save-btn{border-radius:3px;justify-content:center;padding:4px;transition:background-color .2s}.save-btn{background-color:#28a745}.save-btn:hover{background-color:#218838}.cancel-btn{background-color:#dc3545}.cancel-btn:hover{background-color:#c82333}.delete-row-btn{background-color:initial;border-radius:3px;color:#dc3545;min-height:32px;min-width:32px;padding:6px;transition:all .2s}.delete-row-btn:hover{background-color:#dc3545;color:#fff}.edit-row-btn{align-items:center;background-color:#ffc107;border:none;border-radius:3px;color:#212529;cursor:pointer;display:flex;height:32px;justify-content:center;min-height:32px;min-width:32px;padding:6px;transition:all .2s;width:32px}.edit-row-btn:hover{background-color:#e0a800;color:#212529}.edit-row-btn:disabled{background-color:#ffc107!important;color:#212529!important;cursor:not-allowed;opacity:.5}.delete-row-btn:disabled{background-color:initial!important;color:#dc3545!important;opacity:.5}.action-buttons{gap:4px;justify-content:center;width:100%}@media (max-width:768px){.table-header{align-items:stretch;flex-direction:column;gap:15px}.table-actions{flex-wrap:wrap;justify-content:center}.editable-table-container{padding:10px}}.editable-table tbody tr:hover{background-color:#f8f9fa}.editable-table tbody tr:hover td{background-color:inherit}.edit-input:focus,.edit-textarea:focus{outline:2px solid #007bff;outline-offset:-2px}.loading{opacity:.6;pointer-events:none}.error-message,.success-message{align-items:center;border-radius:4px;display:flex;gap:10px;margin-bottom:15px;padding:10px}.close-message{opacity:.7;transition:opacity .2s}.close-message:hover{opacity:1}.loading-container{gap:15px;padding:50px}.new-project-form{background-color:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px}.new-project-form h3{color:#2c3e50;font-size:18px;margin:0 0 20px}.form-grid{grid-gap:15px;gap:15px}.form-group label{color:#2c3e50;font-size:12px;font-weight:600}.form-group input,.form-group select,.form-group textarea{color:#000;font-family:inherit;font-size:12px;padding:8px}.edit-select{background-color:initial;border:none;color:#000;font-family:inherit;font-size:12px;outline:none;padding:4px;width:100%}.edit-project-form{background-color:#fff9c4;border:2px solid #ffc107;border-radius:8px;box-shadow:0 4px 12px #ffc10733;margin:10px;padding:20px}.edit-project-form h3{align-items:center;color:#856404;display:flex;font-size:16px;gap:8px;margin:0 0 20px}.edit-project-form h3:before{content:"✏️";font-size:18px}.readonly-input{background-color:#f8f9fa!important;border:2px solid #e9ecef!important;color:#6c757d!important;cursor:not-allowed!important;font-style:italic}.readonly-input:focus{border-color:#e9ecef!important;box-shadow:none!important}.readonly-input[type=date]{background-color:#f8f9fa!important;color:#6c757d!important;font-style:normal}.readonly-input[type=date]::-webkit-calendar-picker-indicator{cursor:not-allowed;opacity:.5}.permission-granted{cursor:pointer;opacity:1;transition:all .2s ease}.permission-denied{cursor:not-allowed;filter:grayscale(30%);opacity:.5;transition:all .2s ease}.permission-denied:hover{opacity:.6}.btn.permission-denied,button.permission-denied{background-color:#495057!important;border-color:#495057!important;color:#fff!important}.btn.permission-denied:hover,button.permission-denied:hover{background-color:#5a6268!important;border-color:#545b62!important;cursor:not-allowed}input.permission-denied,select.permission-denied,textarea.permission-denied{background-color:#f8f9fa;border-color:#dee2e6;color:#495057}input.permission-denied:focus,select.permission-denied:focus,textarea.permission-denied:focus{border-color:#dee2e6;box-shadow:none}.permission-denied-state{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:help;display:inline-flex;font-size:14px;gap:6px;padding:8px 12px}.permission-denied-state .permission-icon{flex-shrink:0}.permission-denied-state .permission-message{font-style:italic}.permission-info{border:1px solid;border-radius:6px;font-size:12px;margin:4px 0;padding:8px 12px}.permission-info.granted{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.permission-info.denied{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.permission-status-row{align-items:center;display:flex;gap:6px;margin-bottom:4px}.permission-code{font-family:monospace;font-weight:500}.permission-origin{font-style:italic;opacity:.8}.permission-message{align-items:center;display:flex;font-size:11px;gap:4px;margin:4px 0}.permission-details{gap:8px;margin-top:4px}.permission-restriction{background-color:#ffc10733;border:1px solid #ffc10766;border-radius:3px;color:#664d03;font-size:10px;padding:2px 6px}.permission-status{align-items:center;display:inline-flex;gap:2px}.permission-status.granted .permission-granted-icon{color:#28a745}.permission-status.denied .permission-denied-icon{color:#dc3545}.permission-debug-panel{background:#fff;border:2px solid #007bff;border-radius:8px;bottom:20px;box-shadow:0 4px 12px #00000026;font-size:12px;max-width:300px;padding:16px;position:fixed;right:20px;z-index:9999}.permission-debug-panel h4{color:#007bff;font-size:14px;margin:0 0 8px}.permission-summary{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.permission-summary div{border-bottom:1px solid #e9ecef;padding:2px 0}.permission-debug-panel details{margin-top:8px}.permission-debug-panel summary{color:#343a40;cursor:pointer;font-weight:500}.permission-debug-panel ul{margin:8px 0 0;max-height:150px;overflow-y:auto;padding-left:16px}.permission-debug-panel li{font-family:monospace;margin:2px 0}.permission-debug-panel small{color:#495057;font-style:italic}.permission-debugger{bottom:20px;left:20px;position:fixed;z-index:10000}.debug-toggle{align-items:center;background:#007bff;border:none;border-radius:6px;box-shadow:0 2px 8px #007bff4d;color:#fff;cursor:pointer;display:flex;font-size:12px;gap:6px;padding:8px 12px;transition:all .2s ease}.debug-toggle:hover{background:#0056b3;transform:translateY(-1px)}.debug-panel{animation:slideUp .3s ease;background:#7998e5;border:2px solid #007bff;border-radius:8px;bottom:50px;box-shadow:0 8px 24px #00000026;left:0;max-height:70vh;overflow-y:auto;position:absolute;width:400px}.debug-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;justify-content:space-between;padding:12px 16px}.debug-header,.debug-header h4{align-items:center;display:flex}.debug-header h4{color:#007bff;font-size:16px;gap:6px;margin:0}.debug-close{align-items:center;background:none;border:none;color:#495057;cursor:pointer;display:flex;font-size:18px;height:20px;justify-content:center;padding:0;width:20px}.debug-close:hover{color:#dc3545}.debug-content{padding:16px}.debug-section{border-bottom:1px solid #e9ecef;margin-bottom:16px;padding-bottom:12px}.debug-section:last-child{border-bottom:none;margin-bottom:0}.debug-section h5{align-items:center;color:#343a40;display:flex;font-size:14px;gap:6px;margin:0 0 8px}.debug-info div,.debug-stats div{font-size:12px;margin:4px 0}.debug-info strong{color:#007bff}.reload-btn{background:#28a745;border:none;border-radius:4px;color:#fff;font-size:11px;margin-top:8px;padding:4px 8px}.permission-test{display:flex;flex-direction:column;gap:8px}.test-context-input,.test-permission-select{border:1px solid #ddd;border-radius:4px;font-size:12px;padding:6px 8px}.test-result{border-radius:4px;font-size:11px;font-weight:500;padding:6px 8px}.test-result.granted{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.test-result.denied{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.test-result.error{background:#fff3cd;border:1px solid #ffeaa7;color:#664d03}.permissions-list{margin-top:8px;max-height:150px;overflow-y:auto}.permission-item{border-bottom:1px solid #f0f0f0;flex-direction:column;font-size:11px;gap:2px;padding:6px 0}.permission-name{color:#343a40;font-family:monospace}.permission-details{flex-wrap:wrap;gap:6px}.permission-origin{border-radius:2px;font-size:10px;padding:1px 4px}.permission-origin.rol{background:#e3f2fd;color:#1565c0}.permission-origin.personalizado{background:#f3e5f5;color:#6a1b9a}.restriction{background:#fff3e0;border-radius:2px;color:#e65100;font-size:9px;padding:1px 4px}.no-permissions{color:#495057;font-style:italic;padding:16px;text-align:center}.common-permissions{display:flex;flex-direction:column;gap:2px;margin-top:8px;max-height:120px;overflow-y:auto}.common-permission{align-items:center;display:flex;font-size:11px;gap:6px;padding:4px 0}.common-permission.granted .permission-name{color:#155724}.common-permission.denied .permission-name{color:#721c24;opacity:.9}.permission-icon{text-align:center;width:16px}@keyframes permission-denied-shake{0%,to{transform:translateX(0)}25%{transform:translateX(-2px)}75%{transform:translateX(2px)}}.permission-denied:active{animation:permission-denied-shake .3s ease-in-out}.menu-item.permission-denied,.nav-link.permission-denied,.tab-btn.permission-denied{opacity:.4;pointer-events:none}.card.permission-denied,.panel.permission-denied{border-color:#dee2e6;opacity:.7}.card.permission-denied .card-header,.panel.permission-denied .panel-header{background-color:#f8f9fa;color:#495057}[data-permission]:hover:after{background:#333;border-radius:4px;bottom:100%;color:#fff;content:attr(title);font-size:11px;left:50%;padding:4px 8px;pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:1000}[data-requires-approval=true]:before{content:"⚠️";font-size:10px;position:absolute;right:-4px;top:-4px;z-index:1}@media (max-width:768px){.permission-debug-panel{bottom:10px;left:10px;max-width:none;right:10px}.permission-denied-state{font-size:12px;padding:6px 8px}.permission-info{font-size:11px;padding:6px 8px}}@media (prefers-color-scheme:dark){.permission-denied-state{background-color:#343a40;border-color:#495057;color:#adb5bd}.permission-info.granted{background-color:#155724;border-color:#1e7e34;color:#d4edda}.permission-info.denied{background-color:#721c24;border-color:#bd2130;color:#f8d7da}.permission-debug-panel{background:#343a40;border-color:#495057;color:#f8f9fa}}.permission-indicator.compras-only{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.permission-indicator.basic-only{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.permission-indicator.full-edit{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.permission-indicator{align-items:center;border-radius:4px;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.permission-denied{min-height:400px;padding:2rem}.permission-message{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:500px;padding:2rem}.permission-message svg{color:#f39c12;margin-bottom:1rem}.permission-message h3{color:#856404;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.permission-message p{color:#856404;line-height:1.5;margin:.5rem 0}.permission-message p:last-child{margin-bottom:0}.readonly-cell{background-color:#f8f9fa;cursor:not-allowed!important;opacity:.6}.readonly-cell .edit-icon{display:none}.readonly-cell:hover{background-color:#f8f9fa}.estatus-select.disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.6}.estatus-select.disabled:hover{background-color:#f8f9fa}.collapsible-list{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:16px;overflow:hidden}.collapsible-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #0000;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.collapsible-header:hover{background:#e9ecef}.collapsible-header:focus{outline:2px solid #007bff;outline-offset:-2px}.collapsible-title{color:#333;font-size:14px;font-weight:600}.collapsible-arrow{color:#666;font-size:12px;transition:transform .2s ease}.collapsible-arrow.expanded{transform:rotate(180deg)}.collapsible-content{border-top:1px solid #e0e0e0;max-height:300px;overflow-y:auto}.collapsible-items{padding:8px 0}.collapsible-item{border-bottom:1px solid #f0f0f0;display:flex;flex-direction:column;gap:4px;padding:8px 16px}.collapsible-item:last-child{border-bottom:none}.collapsible-item:hover{background:#f8f9fa}.item-name{color:#333;font-size:13px;font-weight:500}.item-detail{color:#666;font-size:12px;font-style:italic}.collapsible-empty{color:#999;font-size:13px;font-style:italic;padding:16px;text-align:center}.collapsible-list.compact .collapsible-header{padding:8px 12px}.collapsible-list.compact .collapsible-item{padding:6px 12px}.collapsible-list.compact .collapsible-title{font-size:13px}.collapsible-list.success .collapsible-header{background:#d4edda;border-color:#c3e6cb}.collapsible-list.warning .collapsible-header{background:#fff3cd;border-color:#ffeaa7}.collapsible-list.info .collapsible-header{background:#d1ecf1;border-color:#bee5eb}.collapsible-content::-webkit-scrollbar{width:6px}.collapsible-content::-webkit-scrollbar-track{background:#f1f1f1}.collapsible-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.collapsible-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.perfiles-manager-container{background-color:#f8f9fa;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:20px}.error-message,.success-message{border-radius:8px;font-weight:500}.error-message{background-color:#f8d7da}.success-message{background-color:#d4edda}.close-message{border-radius:2px;padding:2px;transition:background-color .2s}.close-message:hover{background-color:#0000001a}.tabs-container{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.tabs-nav{display:flex;gap:4px}.tab-btn{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;color:#6c757d;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:12px 20px;transition:all .3s ease}.tab-btn:hover{background:#e9ecef;color:#495057}.tab-btn.active{background:#007bff;border-color:#007bff;color:#fff}.add-profile-btn{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:12px 20px;transition:background-color .3s}.add-profile-btn:hover{background:#218838}.add-profile-btn:disabled{background:#6c757d;cursor:not-allowed}.tab-content{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.profiles-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;justify-content:space-between;padding:20px 24px}.header-info,.profiles-header{align-items:center;display:flex}.header-info{gap:12px}.header-info h2{font-size:20px}.header-info svg{color:#007bff}.profiles-count{background:#007bff;border-radius:20px;color:#fff;font-size:14px;font-weight:500;padding:6px 12px}.loading-container p{font-size:16px;margin-top:16px}.profiles-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));padding:24px}.profile-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;min-height:320px;padding:20px;transition:all .3s ease}.profile-card:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26}.profile-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.profile-header h3{color:#2c3e50;font-size:18px;font-weight:600;margin:0}.profile-status{margin-left:12px}.status-badge{font-size:12px;font-weight:500;padding:4px 8px}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.profile-info{margin-bottom:16px}.info-row{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px;padding:4px 0}.info-row:last-child{margin-bottom:0}.info-row .label{color:#6c757d;font-weight:500;min-width:80px}.info-row .value{color:#495057;flex:1 1;line-height:1.3;max-width:60%;text-align:right;word-break:break-word}.badge-experiencia,.badge-nivel,.badge-total{background:#e9ecef;border-radius:12px;color:#495057;font-size:11px;font-weight:500;letter-spacing:.3px;padding:2px 8px;text-transform:uppercase}.badge-total{background:#d4edda;color:#155724;font-weight:600}.badge-experiencia[data-nivel=JUNIOR]{background:#cce5ff;color:#0056b3}.badge-experiencia[data-nivel=SENIOR]{background:#ffe6cc;color:#c50}.badge-experiencia[data-nivel=EXPERTO]{background:#cfc;color:#060}.badge-nivel[data-nivel=OBRA]{background:#e6f3ff;color:#06c}.badge-nivel[data-nivel=REGIONAL]{background:#fff0e6;color:#c60}.badge-nivel[data-nivel=GENERAL]{background:#f0e6ff;color:#60c}.profile-actions{border-top:1px solid #e9ecef;display:flex;gap:8px;justify-content:flex-end;padding-top:16px}.delete-btn,.edit-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.edit-btn{background:#ffc107;color:#fff}.edit-btn:hover{background:#e0a800}.delete-btn{background:#dc3545;color:#fff}.delete-btn:hover{background:#c82333}.delete-btn:disabled,.edit-btn:disabled{background:#6c757d;cursor:not-allowed}.empty-state{grid-column:1/-1}.empty-state svg{margin-bottom:20px;opacity:.5}.empty-state h3{font-size:20px;margin:0 0 8px}.empty-state p{color:#6c757d;margin:0 0 24px}.add-first-btn{align-items:center;background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:12px 24px;transition:background-color .3s}.add-first-btn:hover{background:#0056b3}.modal-overlay{background-color:#00000080}.modal-content{max-width:500px;width:90%}.modal-header h3{color:#2c3e50;font-size:18px}.modal-close-btn{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;padding:4px;transition:background-color .2s}.modal-close-btn:hover{background:#f8f9fa;color:#495057}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-group input{border:1px solid #ced4da;border-radius:4px;font-size:14px;padding:10px 12px;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}.form-group input:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:0}.checkbox-group{align-items:center;display:flex}.checkbox-label{font-weight:400!important;gap:8px;margin-bottom:0!important}.checkbox-label input[type=checkbox]{margin:0;width:auto!important}.checkbox-label span{color:#495057;font-size:14px}.modal-footer{align-items:center;border-radius:0 0 8px 8px}.modal-footer .cancel-btn,.modal-footer .save-btn{align-items:center;border-radius:4px;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px}.modal-footer .save-btn{transition:background-color .3s}.modal-footer .save-btn:hover{background:#218838}.modal-footer .cancel-btn{transition:background-color .3s}.modal-footer .cancel-btn:hover{background:#5a6268}@media (max-width:768px){.perfiles-manager-container{padding:15px}.tabs-container{align-items:stretch;flex-direction:column;gap:16px}.tabs-nav{justify-content:center}.tab-btn{font-size:14px;padding:10px 16px}.profiles-grid{gap:16px;grid-template-columns:1fr;padding:16px}.profile-card{padding:16px}.profile-header{align-items:flex-start;flex-direction:column;gap:8px}.profile-status{margin-left:0}.modal-content{margin:20px;width:95%}.modal-body,.modal-footer,.modal-header{padding-left:16px;padding-right:16px}}.modal-form .form-sections{margin-top:20px}.form-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.form-section h4{border-bottom:1px solid #dee2e6;color:#495057;font-size:16px;font-weight:600;margin:0 0 15px;padding-bottom:8px}.form-section .form-row{display:flex;gap:15px;margin-bottom:15px}.form-section .form-group{flex:1 1}.form-section .form-group:last-child{margin-bottom:0}.form-section.basic-info{background:#fff;border-color:#007bff}.form-section.basic-info h4{color:#007bff}.form-section.residente-section{background:#f0f8ff;border-color:#28a745}.form-section.residente-section h4{color:#28a745}.form-section.coordinador-section{background:#fff8f0;border-color:#ffc107}.form-section.coordinador-section h4{color:#856404}.form-section.director-section{background:#f8f0ff;border-color:#6f42c1}.form-section.director-section h4{color:#6f42c1}.form-section .form-control,.form-section .form-select{background:#fff;border:1px solid #ced4da}.form-section .form-control:focus,.form-section .form-select:focus{border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.profile-info .hierarchy-info{background:#f1f3f4;border-radius:6px;margin:10px 0;padding:12px}.hierarchy-info .supervisor-info{align-items:center;color:#495057;display:flex;font-size:13px;gap:8px;margin-bottom:6px}.hierarchy-info .authorization-limits{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.authorization-limits .limit-badge{background:#e9ecef;border-radius:10px;color:#495057;font-size:11px;font-weight:500;padding:2px 8px}.limit-badge.high{background:#ffebee;color:#c62828}.limit-badge.medium{background:#fff3e0;color:#ef6c00}.limit-badge.low{background:#e8f5e8;color:#2e7d32}.form-control.invalid,.form-select.invalid{border-color:#dc3545;box-shadow:0 0 0 .2rem #dc354540}.form-control.valid,.form-select.valid{border-color:#28a745;box-shadow:0 0 0 .2rem #28a74540}.field-error{color:#dc3545;margin-top:4px}.supervision-section{border-top:1px solid #e9ecef;margin-top:16px;padding-top:12px}.supervision-section .collapsible-list{margin-bottom:8px}.supervised-person{display:flex;flex-direction:column;gap:4px;padding:4px 0}.supervised-person .person-name{color:#2c3e50;font-size:13px;font-weight:600}.supervised-person .person-detail{color:#6c757d;font-size:12px;font-style:italic;margin-left:8px}.profile-card .supervision-section .collapsible-list{border:1px solid #dee2e6}.profile-card .supervision-section .collapsible-header{background:#f1f3f4;font-size:12px}.profile-card .supervision-section .collapsible-title{font-size:12px;font-weight:600}.profile-card .supervision-section .collapsible-content{max-height:200px}.modal-content.small{max-width:520px}.summary .info-row{display:flex;gap:8px;margin-bottom:6px}.summary .label{color:#9aa3af;min-width:120px}.btn-secondary{background:#0000;border:1px solid #2d3748;border:1px solid var(--border-color,#2d3748);color:#e2e8f0;color:var(--text-color,#e2e8f0)}.btn-secondary:hover{background:#ffffff0f}.permission-denied{display:grid;padding:32px;place-items:center}.permission-message{grid-gap:8px;display:grid;gap:8px;text-align:center}.pm-input{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:8px;outline:none;padding:10px 12px;transition:box-shadow .15s ease,border-color .15s ease;width:100%}.pm-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.pm-input--invalid{border-color:#e11d48!important;box-shadow:0 0 0 3px #e11d481f}.field-error{color:#e11d48}.field-error,.form-help{font-size:12px;margin-top:6px}.form-help{color:#6b7280}.folios-manager-container{padding:20px}.loading-container{min-height:300px}.loading-container .spinning{animation:spin 1s linear infinite}.error-message,.success-message{align-items:center;border-radius:4px;display:flex;gap:10px;margin-bottom:20px;padding:12px 16px}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.success-message{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.close-message{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;padding:0}.table-header{padding:20px}.table-header h2{color:#2c3e50;font-size:1.5rem;margin:0}.add-btn{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;height:40px;justify-content:center;min-width:140px;padding:8px 16px;transition:all .2s ease}.add-btn:hover{background:#218838}.add-btn:disabled{background:#6c757d;cursor:not-allowed}.bulk-create-btn{align-items:center;background:#17a2b8;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;height:40px;justify-content:center;min-width:140px;padding:8px 16px;transition:all .2s ease}.bulk-create-btn:hover{background:#138496}.bulk-create-btn:disabled{background:#6c757d;cursor:not-allowed}.filters-section{gap:20px}.filter-group{gap:10px}.filter-group label{color:#495057;font-weight:500;white-space:nowrap}.filter-select{min-width:200px}.summary-info{display:flex;gap:20px}.summary-item{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;color:#495057;display:flex;font-weight:500;gap:8px;padding:8px 16px}.summary-item.local-indicator{background:#fff3cd;border-color:#ffc107;color:#856404}.summary-item.permission-indicator.compras-only{background:#e8f4fd;border-color:#06c;color:#004080}.summary-item.permission-indicator.full-edit{background:#d4edda;border-color:#28a745;color:#155724}.bulk-create-form{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:25px}.bulk-create-form h3{border-bottom:2px solid #3498db;border-bottom-color:#17a2b8;color:#2c3e50;margin:0 0 20px;padding-bottom:10px}.bulk-form-content{display:flex;flex-direction:column;gap:20px}.bulk-form-group{display:flex;flex-direction:column;max-width:400px}.bulk-form-group label{color:#495057;font-weight:500;margin-bottom:5px}.bulk-form-group input,.bulk-form-group select{border:1px solid #ced4da;border-radius:4px;font-size:14px;padding:10px;transition:border-color .3s}.bulk-form-group input:focus,.bulk-form-group select:focus{border-color:#17a2b8;box-shadow:0 0 0 2px #17a2b833;outline:none}.bulk-instructions{background:#f8f9fa;border-left:4px solid #17a2b8;border-radius:6px;padding:20px}.bulk-instructions h4{color:#2c3e50;font-size:1.1rem;margin:0 0 15px}.bulk-instructions ol{color:#495057;line-height:1.6;margin:0 0 20px;padding-left:20px}.bulk-instructions li{margin-bottom:8px}.bulk-example{background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:15px}.bulk-example strong{color:#2c3e50;display:block;margin-bottom:10px}.bulk-example pre{word-wrap:break-word;background:#f1f3f4;border:1px solid #e9ecef;border-radius:4px;color:#495057;font-size:12px;line-height:1.4;margin:0;padding:10px;white-space:pre-wrap}.bulk-form-actions{border-top:1px solid #dee2e6;display:flex;gap:10px;justify-content:flex-end;padding-top:20px}.form-grid{grid-gap:20px;gap:20px;margin-bottom:20px}.form-group label{color:#495057;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ced4da;transition:border-color .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.readonly-input{background-color:#e9ecef!important;cursor:not-allowed}.form-group small{color:#6c757d;font-size:12px;margin-top:4px}.form-group textarea{min-height:80px}.form-actions{border-top:1px solid #dee2e6;display:flex;gap:10px;justify-content:flex-end;padding-top:20px}.cancel-btn,.save-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 20px;transition:background .3s}.save-btn{background:#28a745;color:#fff}.save-btn:hover{background:#218838}.save-btn:disabled{background:#6c757d;cursor:not-allowed}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover{background:#5a6268}.table-wrapper{background:#fff;box-shadow:0 2px 4px #0000001a;height:auto;margin-bottom:20px;max-height:none;overflow:hidden;overflow-y:auto}.folios-manager-container:has(.bulk-approval-panel) .table-wrapper{margin-bottom:120px}.folios-table{font-size:14px;min-width:1500px;width:1500px}.folios-table th{background:#3498db;border-bottom:1px solid #2980b9;color:#fff;padding:12px 8px;position:-webkit-sticky;position:sticky;text-overflow:ellipsis;top:0;white-space:nowrap;z-index:10}.folios-table td{border-bottom:1px solid #dee2e6;padding:8px 6px;vertical-align:top}.folios-table td[data-column=concepto_presupuesto],.folios-table td[data-column=descripcion_insumo]{word-wrap:break-word;max-height:60px;overflow-y:auto;white-space:normal}.folios-table tbody tr:hover{background:#f8f9fa}.local-folio-row{background:#fff3cd!important;border-left:4px solid #ffc107}.local-folio-row:hover{background:#ffeaa7!important}.local-folio-row .cell-content{position:relative}.local-folio-row .cell-content:before{color:#ffc107;content:"●";font-size:8px;position:absolute;right:2px;top:2px}.action-buttons{display:flex;gap:5px}.delete-row-btn{align-items:center;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .3s;width:32px}.delete-row-btn:hover{background:#c82333}.delete-row-btn:disabled{background:#6c757d;cursor:not-allowed}.cell-content{align-items:center;border-radius:4px;box-sizing:border-box;cursor:pointer;display:flex;justify-content:space-between;min-height:20px;padding:4px 6px;position:relative;transition:background .2s;width:100%}.cell-content.readonly-cell{background-color:#f8f9fa;border:1px solid #e9ecef;color:#6c757d;cursor:default}.cell-content.readonly-cell:hover{background-color:#f8f9fa}.cell-content:hover{background:#e3f2fd}.cell-text{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:break-word}.cell-content[data-column=concepto_presupuesto] .cell-text,.cell-content[data-column=descripcion_insumo] .cell-text{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;line-height:1.3;max-height:40px;overflow:hidden;white-space:normal}.edit-icon{color:#3498db;flex-shrink:0;margin-left:4px;opacity:0;transition:opacity .2s}.cell-content:hover .edit-icon{opacity:1}.editing-cell{position:relative}.edit-input,.edit-select,.edit-textarea{border:2px solid #3498db;border-radius:4px;font-size:14px;padding:8px;width:100%}.edit-textarea{min-height:80px;resize:vertical}.edit-actions{display:flex;gap:2px;position:absolute;right:-5px;top:-5px;z-index:1000}.edit-actions .cancel-btn,.edit-actions .save-btn{align-items:center;display:flex;font-size:12px;height:24px;justify-content:center;padding:0;width:24px}.edit-actions .save-btn{background:#28a745}.edit-actions .cancel-btn{background:#dc3545}.totals-row{background:#f8f9fa!important;border-top:2px solid #3498db;font-weight:600}.totals-row td{color:#2c3e50;padding:15px 8px;text-align:right}.empty-state{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-state h3{margin:20px 0 10px}.empty-state p{line-height:1.5;max-width:400px}@media (max-width:768px){.folios-manager-container{padding:15px}.filters-section,.table-header{align-items:flex-start;flex-direction:column;gap:15px}.summary-info{flex-direction:column;gap:10px;width:100%}.summary-item{justify-content:center}.form-grid{grid-template-columns:1fr}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}}.readonly-field{position:relative}.disabled-input{background-color:#f8f9fa!important;border:1px solid #e9ecef!important;color:#6c757d!important;cursor:not-allowed!important;opacity:.8}.disabled-input:focus{border-color:#e9ecef!important;box-shadow:none!important}.field-help{font-size:.75rem;font-style:italic}.save-all-btn{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;height:40px;justify-content:center;min-width:140px;padding:8px 16px;transition:all .2s ease}.save-all-btn:hover:not(:disabled){background:#218838}.save-all-btn:disabled{background:#6c757d;cursor:not-allowed}.discard-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;height:40px;justify-content:center;min-width:140px;padding:8px 16px;transition:all .2s ease}.discard-btn:hover:not(:disabled){background:#c82333}.discard-btn:disabled{background:#6c757d;cursor:not-allowed}.cell-content.has-pending-changes{background-color:#fff3cd;border-left:3px solid #ffc107;position:relative}.pending-indicator{animation:pulse-pending 1.5s ease-in-out infinite;color:#ffc107;font-size:12px;font-weight:700;line-height:1;position:absolute;right:2px;top:2px}@keyframes pulse-pending{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.has-pending-changes .edit-icon{color:#856404}.has-pending-changes:hover{background-color:#ffeaa7}.folios-table td[data-column=cantidad],.folios-table th[data-column=cantidad]{border-right:3px solid #ffc107!important}.folios-table th[data-column=cantidad]{position:relative}.folios-table th[data-column=cantidad]:after{color:#ffc107;content:"COMPRAS →";font-size:10px;font-weight:500;pointer-events:none;position:absolute;right:-60px;top:50%;transform:translateY(-50%);white-space:nowrap}.compras-header{background:#e8f4fd!important;border-left:1px solid #d1ecf1!important;color:#2c3e50!important}.compras-cell{background-color:#f4fbff!important;border-left:1px solid #e3f2fd!important}.compras-cell:hover{background-color:#e8f4fd!important}.table-header{align-items:flex-start;gap:20px;margin-bottom:20px}.header-left{display:flex;flex-direction:column;gap:8px}.solicitud-status-info{align-items:center;display:flex;gap:12px}.solicitud-numero{color:#6c757d;font-size:14px;font-weight:500}.estatus-badge{border-radius:16px;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.estatus-en_elaboracion{background:#e9ecef;color:#495057}.estatus-en_espera{background:#ffeaa7;border:1px solid #fdcb6e;color:#d63031}.estatus-en_cotizacion{background:#cce7ff;color:#06c}.estatus-en_supervision{background:#fff3cd;color:#856404}.estatus-en_compra{background:#d4edda;color:#155724}.estatus-finalizada{background:#d1ecf1;color:#0c5460}.estatus-rechazada{background:#f8d7da;color:#721c24}.estatus-cancelada{background:#e2e3e5;color:#383d41}.validation-indicator{border-radius:12px;font-size:11px;font-weight:500;letter-spacing:.3px;margin-left:12px;padding:4px 8px;text-transform:none}.validation-indicator.valid{background:#d4edda;color:#155724}.validation-indicator.invalid{background:#fff3cd;color:#856404;cursor:help}.validation-pending,.validation-ready{align-items:center;display:flex;gap:4px}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;height:40px;justify-content:center;min-width:140px;padding:8px 16px;transition:all .2s ease}.action-btn:disabled{cursor:not-allowed;opacity:.6}.action-btn.btn-primary{background:#007bff;color:#fff}.action-btn.btn-primary:hover:not(:disabled){background:#0056b3}.action-btn.btn-warning{background:#ffc107;color:#212529}.action-btn.btn-warning:hover:not(:disabled){background:#e0a800}.action-btn.btn-success{background:#28a745;color:#fff}.action-btn.btn-success:hover:not(:disabled){background:#1e7e34}.action-btn.btn-danger{background:#dc3545;color:#fff}.action-btn.btn-danger:hover:not(:disabled){background:#c82333}.table-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}@media (max-width:768px){.table-header{align-items:stretch;flex-direction:column}.table-actions{justify-content:flex-start}.action-btn{font-size:12px;padding:6px 12px}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;box-sizing:border-box;height:100vh;padding:10px;width:100vw;z-index:2000}.modal-overlay-top{background:#000000b3;z-index:2100!important}.modal-content{animation:modalSlideIn .3s ease-out;box-shadow:0 10px 25px #0003;color:#212529;margin:10px;max-height:98vh;max-width:1000px;min-width:700px;width:98%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{flex-shrink:0;padding:20px 24px 16px}.modal-header h3{color:#212529;font-size:1.25rem;font-weight:600}.close-modal-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.close-modal-btn:hover{background:#f8f9fa;color:#333}.modal-body{display:flex;flex:1 1;flex-direction:column;overflow:hidden;padding:20px 24px}.modal-footer{flex-shrink:0;padding:16px 24px 20px}.form-group{margin-bottom:20px}.form-group label{color:#212529;display:block;margin-bottom:8px}.form-input{background-color:#fff;border:1px solid #ddd;border-radius:4px;color:#212529;font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.field-help{font-size:12px;line-height:1.4;margin-top:6px}.modal-footer .save-btn{align-items:center;background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:background-color .2s ease}.modal-footer .save-btn:hover:not(:disabled){background:#218838}.modal-footer .save-btn:disabled{background:#6c757d;cursor:not-allowed}.modal-footer .cancel-btn{align-items:center;background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:background-color .2s ease}.modal-footer .cancel-btn:hover:not(:disabled){background:#5a6268}.modal-footer .cancel-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.modal-content{margin:10px;min-width:320px;width:98%}.modal-body,.modal-footer,.modal-header{padding-left:16px;padding-right:16px}.modal-footer{flex-direction:column}.modal-footer .cancel-btn,.modal-footer .save-btn{justify-content:center;width:100%}}.folios-table td input[type=checkbox],.folios-table th input[type=checkbox]{accent-color:#007bff;cursor:pointer;height:16px;margin:0;width:16px}.folios-table th input[type=checkbox]{accent-color:#28a745;height:18px;width:18px}.folios-table.with-checkboxes td:first-child,.folios-table.with-checkboxes th:first-child{background:#fff;border-right:2px solid #dee2e6;box-shadow:2px 0 4px #0000001a;left:0;position:-webkit-sticky;position:sticky;z-index:10}.folios-table.with-checkboxes th:first-child{background:#f8f9fa;font-weight:600;z-index:11}.folios-table.with-checkboxes tbody tr:hover td:first-child{background:#f5f5f5}.folios-table.with-checkboxes tbody tr:nth-child(2n) td:first-child{background:#fdfdfd}.folios-table.with-checkboxes tbody tr:nth-child(2n):hover td:first-child{background:#f1f3f4}.folios-table:not(.with-checkboxes) td:first-child,.folios-table:not(.with-checkboxes) th:first-child{background:inherit;border-right:inherit;box-shadow:none;position:static;z-index:auto}.table-wrapper{border:1px solid #dee2e6;border-radius:8px;overflow-x:auto;position:relative}.folios-table{min-width:100%;width:-webkit-max-content;width:max-content}.bulk-approval-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #dee2e6;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:12px 20px}.selection-info{color:#212529;font-weight:600;gap:8px}.bulk-actions,.selection-info{align-items:center;display:flex}.bulk-actions{gap:15px}.filter-selection-buttons{display:flex;gap:8px}.btn-filter-select{background:#e9ecef;border:1px solid #ced4da;border-radius:4px;cursor:pointer;font-size:.8rem;padding:4px 8px;transition:all .2s ease}.btn-filter-select:hover{background:#dee2e6;border-color:#adb5bd}.approval-controls{align-items:center;display:flex;gap:10px}.approval-action-select{border:1px solid #ced4da;border-radius:4px;font-size:.9rem;padding:6px 10px}.btn-bulk-approve{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:background-color .2s ease}.btn-bulk-approve:hover:not(:disabled){background:#218838}.btn-bulk-approve:disabled{cursor:not-allowed;opacity:.6}.btn-bulk-proveedor{background:#17a2b8;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:background-color .2s ease}.btn-bulk-proveedor:hover:not(:disabled){background:#138496}.btn-bulk-proveedor:disabled{cursor:not-allowed;opacity:.6}.btn-clear-selection{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 12px;transition:background-color .2s ease}.btn-clear-selection:hover{background:#545b62}.bulk-approval-modal{max-width:1700px!important}.bulk-approval-modal,.bulk-proveedor-modal{color:#212529;display:flex!important;flex-direction:column!important;height:95vh!important;margin:2.5vh auto!important;max-height:95vh!important;min-width:1200px!important;overflow:hidden!important;width:95vw!important}.bulk-proveedor-modal{max-width:1600px!important}.bulk-proveedor-summary{display:flex;flex:1 1;flex-direction:column;margin-bottom:20px;min-height:0}.bulk-proveedor-summary p{color:#212529;font-size:1rem;margin:10px 0}.proveedor-selection{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;margin:20px 0;padding:15px}.proveedor-selection label{color:#212529;display:block;font-weight:600;margin-bottom:8px}.bulk-proveedor-select{background:#fff;border:1px solid #ced4da;border-radius:4px;color:#212529;font-size:1rem;padding:10px;width:100%}.bulk-proveedor-select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.current-proveedor{color:#495057;font-size:.9em;font-style:italic}.preview-change{background:#d4edda;border:1px solid #c3e6cb;border-radius:4px;margin-top:15px;padding:10px}.preview-change p{color:#155724;font-weight:600;margin:0}.btn-confirm-bulk-proveedor{background:#17a2b8;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-width:120px;padding:12px 24px;text-align:center}.btn-confirm-bulk-proveedor:hover:not(:disabled){background:#138496}.btn-confirm-bulk-proveedor:disabled{cursor:not-allowed;opacity:.6}.bulk-approval-summary{display:flex;flex:1 1;flex-direction:column;margin-bottom:20px;min-height:0}.bulk-approval-summary p{color:#212529;font-size:1rem;margin:10px 0}.oc-info{background:#d1ecf1;border:1px solid #bee5eb;border-radius:4px;color:#212529;font-style:italic;padding:12px}.selected-folios-preview{background:#fff;border:1px solid #dee2e6;border-radius:4px;display:flex;flex:1 1;flex-direction:column;margin-top:20px;min-height:0;overflow:hidden}.selected-folios-preview h4{background:#f8f9fa;border-bottom:1px solid #dee2e6;color:#212529;font-size:.9rem;font-weight:600;margin:0;padding:12px 15px}.folios-list{background:#fafafa;border:none;border-radius:0;flex:1 1!important;min-height:0;overflow-y:auto!important}.folio-preview-item{grid-gap:10px;background:#fff;border-bottom:1px solid #e9ecef;color:#212529;display:grid;font-size:.85rem;gap:10px;grid-template-columns:80px 1fr 120px;padding:10px 15px;transition:background-color .2s ease}.folio-preview-item:hover{background-color:#f8f9fa}.folio-preview-item:last-child{border-bottom:none}.folios-list-empty{background:#f8f9fa;color:#6c757d;font-style:italic;padding:30px;text-align:center}.folio-preview-item.more-items{color:#495057;font-style:italic;grid-template-columns:1fr;text-align:center}.progress-section{background:#f8f9fa;border-radius:4px;margin-top:20px;padding:15px}.progress-info{align-items:center;color:#212529;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:8px}.completed-indicator{color:#28a745;font-weight:600}.progress-bar{background:#e9ecef;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:#28a745;height:100%;transition:width .3s ease}.progress-errors{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;margin-top:15px;padding:10px}.progress-errors h5{color:#721c24;font-size:.9rem;margin:0 0 8px}.progress-errors ul{color:#721c24;font-size:.85rem;margin:0;padding-left:20px}.btn-confirm-bulk{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-width:120px;padding:12px 24px;text-align:center}.btn-confirm-bulk:hover{background:#218838}.btn-cancel{background:#6c757d;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;min-width:120px;padding:12px 24px;text-align:center}.btn-cancel:hover{background:#545b62}.btn-close-completed{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:10px 20px}.btn-close-completed:hover{background:#0056b3}.loading-indicator{align-items:center;color:#212529;display:flex;gap:10px}.loading-indicator .spinning{animation:spin 1s linear infinite}@media (max-width:768px){.bulk-approval-panel{left:2.5%;min-width:95vw;transform:none}.bulk-approval-header{align-items:stretch}.approval-controls,.bulk-actions,.bulk-approval-header{flex-direction:column;gap:10px}.approval-controls .btn-bulk-approve,.approval-controls .btn-bulk-proveedor,.approval-controls .btn-clear-selection{justify-content:center;width:100%}.filter-selection-buttons{flex-wrap:wrap}.folio-preview-item{gap:5px;grid-template-columns:1fr}.bulk-proveedor-modal{margin:5px;width:98%}}.oc-summary-section{border:1px solid #e9ecef;border-radius:8px;margin:.5rem 0;overflow:hidden;transition:all .3s ease}.oc-summary-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;transition:background-color .2s ease}.oc-summary-header:hover{background:#e9ecef}.oc-summary-header h4{align-items:center;color:#495057;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0}.oc-summary-toggle{align-items:center;background:none;border:none;color:#6c757d;cursor:pointer;display:flex;font-size:1.2rem;height:24px;justify-content:center;padding:0;transition:transform .3s ease;width:24px}.oc-summary-toggle.expanded{transform:rotate(180deg)}.oc-summary-content{max-height:0;overflow:hidden;transition:max-height .3s ease}.oc-summary-content.expanded{max-height:300px}.oc-summary-content-inner{padding:1rem}.filters-section{flex-wrap:wrap;gap:15px;padding:12px 20px}.filters-section,.table-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.table-header{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:15px 20px}.folios-manager-container{background:#f8f9fa;display:flex;flex-direction:column;padding:15px}.bulk-approval-panel{animation:slideInUp .3s ease-out;background:#fff;border:2px solid #007bff;border-radius:8px;bottom:20px;box-shadow:0 4px 12px #00000026;left:20px;margin:0 auto;max-width:1200px;position:fixed;right:20px;z-index:1000}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.btn-open-bulk-approval{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:6px;box-shadow:0 2px 4px #28a7454d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;justify-content:center;min-width:180px;padding:10px 20px;transition:all .2s ease}.btn-open-bulk-approval:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1ea084);box-shadow:0 4px 8px #28a74566;transform:translateY(-1px)}.btn-open-bulk-approval:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.project-analytics{background:#f8f9fa;min-height:100vh;padding:20px}.analytics-header{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.header-info h2{color:#2c3e50;font-size:24px;margin:0}.project-name{color:#7f8c8d;font-size:16px;margin:5px 0 0}.metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.metric-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;gap:15px;padding:20px}.metric-card,.metric-icon{align-items:center;display:flex}.metric-icon{background:#3498db;border-radius:50%;color:#fff;justify-content:center;padding:12px}.metric-content h3{color:#2c3e50;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.metric-value{color:#2c3e50;font-size:24px;font-weight:700;margin:0 0 5px}.metric-value.over-budget{color:#e74c3c}.metric-subtitle{color:#95a5a6;font-size:12px}.charts-section{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:30px}.chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.chart-container h3{align-items:center;color:#2c3e50;display:flex;font-size:18px;gap:8px;margin:0 0 20px}.summary-table{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.summary-table h3{color:#2c3e50;font-size:18px;margin:0 0 20px}.analytics-table{border-collapse:collapse;margin-top:10px;width:100%}.analytics-table td,.analytics-table th{border-bottom:1px solid #ecf0f1;padding:12px;text-align:left}.analytics-table td{color:#2c3e50;font-weight:500}.analytics-table th{background:#f8f9fa;color:#2c3e50;font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.analytics-table tr:hover{background:#f8f9fa}.analytics-table td:nth-child(3),.analytics-table td:nth-child(4){font-weight:600;text-align:right}.analytics-loading{align-items:center;background:#fff;border-radius:8px;display:flex;flex-direction:column;justify-content:center;margin:20px;min-height:400px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ecf0f1;border-radius:50%;border-top-color:#3498db;height:40px;margin-bottom:20px;width:40px}.analytics-loading p{color:#7f8c8d;font-size:16px;margin:0}.analytics-error{align-items:center;background:#fff;border-radius:8px;display:flex;flex-direction:column;justify-content:center;margin:20px;min-height:400px;padding:40px}.analytics-error p{color:#e74c3c;font-size:16px;margin-bottom:20px;text-align:center}.btn{display:inline-flex;height:40px;justify-content:center;min-width:120px;padding:12px 24px}.btn-primary:hover{background:#2980b9;transform:translateY(-1px)}.btn-secondary:hover{background:#7f8c8d;transform:translateY(-1px)}.btn-outline{border:2px solid #3498db;color:#3498db}.btn-outline:hover:not(:disabled){background:#3498db;color:#fff}@media (max-width:768px){.project-analytics{padding:10px}.analytics-header{flex-direction:column;gap:15px;text-align:center}.charts-section,.metrics-grid{grid-template-columns:1fr}.chart-container{padding:15px}.metric-card{flex-direction:column;text-align:center}.analytics-table{font-size:12px}.analytics-table td,.analytics-table th{padding:8px 4px}}.recharts-tooltip-wrapper{background:#fff!important;border:1px solid #ecf0f1!important;border-radius:6px!important;box-shadow:0 4px 6px #0000001a!important}.recharts-tooltip-label{color:#2c3e50!important;font-weight:600!important;margin-bottom:5px!important}.recharts-tooltip-item{color:#34495e!important;font-size:14px!important}.recharts-legend-wrapper{padding-top:20px!important}.recharts-legend-item{margin-right:20px!important}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#ecf0f1!important}.recharts-cartesian-axis-tick-value{fill:#7f8c8d!important;font-size:12px!important}.text-success{color:#28a745!important;font-weight:600}.text-warning{color:#ffc107!important;font-weight:600}.summary-row{background-color:#f8f9fa;border-top:2px solid #dee2e6;font-weight:700}.summary-row td{border-top:2px solid #dee2e6;padding:12px 8px!important}.avance-editing{display:flex;flex-direction:column;gap:10px;width:100%}.avance-input-group{align-items:center;display:flex;gap:5px}.avance-input{border:2px solid #3498db;border-radius:6px;font-size:16px;font-weight:700;outline:none;padding:8px 12px;text-align:center;transition:all .2s ease;width:80px}.avance-input:focus{border-color:#2980b9;box-shadow:0 0 0 3px #3498db1a}.avance-input:disabled{background-color:#f8f9fa;border-color:#dee2e6;cursor:not-allowed}.avance-percent{color:#2c3e50;font-size:18px;font-weight:700}.avance-actions{display:flex;gap:8px;justify-content:flex-start}.btn-cancel,.btn-save{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;height:36px;justify-content:center;padding:0;transition:all .2s ease;width:36px}.btn-save{background-color:#28a745;color:#fff}.btn-save:hover:not(:disabled){background-color:#218838;transform:translateY(-1px)}.btn-save:disabled{background-color:#6c757d;cursor:not-allowed;transform:none}.btn-cancel{background-color:#dc3545;color:#fff}.btn-cancel:hover:not(:disabled){background-color:#c82333;transform:translateY(-1px)}.btn-cancel:disabled{background-color:#6c757d;cursor:not-allowed;transform:none}.avance-display{align-items:center;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;padding:8px;transition:all .2s ease;width:100%}.avance-display:hover{background-color:#f8f9fa}.edit-icon{color:#6c757d;transition:color .2s ease}.avance-display:hover .edit-icon{color:#3498db}.spinner{border:2px solid #0000;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.spinner-small{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;display:inline-block;height:14px;margin-right:6px;vertical-align:middle;width:14px}@media (max-width:768px){.avance-input{font-size:14px;width:70px}.avance-percent{font-size:16px}.btn-cancel,.btn-save{height:32px;width:32px}}.solicitudes-manager{background-color:#f8f9fa;min-height:100vh;padding:20px}.solicitudes-header{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.header-title{align-items:center;display:flex;gap:12px}.header-icon{color:#007bff}.header-title h2{color:#333;margin:0}.solicitudes-count{background:#e9ecef;border-radius:12px;color:#6c757d;font-size:.85em;font-weight:500;padding:4px 8px}.cache-status{margin-left:12px}.cache-indicator{background:#e3f2fd;border:1px solid #bbdefb;border-radius:12px;color:#1976d2;font-size:.75em;font-weight:500;padding:4px 8px}.pending-indicator{color:#f57c00;font-weight:600}.cache-loaded{color:#388e3c;filter:drop-shadow(0 0 2px rgba(56,142,60,.3));font-size:1.1em;margin-left:4px}.btn-outline{background:#fff;border:2px solid #007bff;color:#007bff}.btn-outline:hover{background:#007bff;color:#fff}.btn-outline:disabled{background:#f8f9fa;border-color:#dee2e6;color:#6c757d;cursor:not-allowed}.animate-spin{animation:spin 1s linear infinite}.header-actions{gap:10px}.reload-btn{align-items:center;background:#fff;border:2px solid #007bff;border-radius:6px;color:#007bff;cursor:pointer;display:flex;font-size:12px;height:38px;justify-content:center;min-width:40px;padding:8px 10px;transition:all .2s ease}.reload-btn:hover:not(:disabled){background:#007bff;color:#fff}.reload-btn:disabled{background:#f8f9fa;border-color:#dee2e6;color:#6c757d;cursor:not-allowed}.reload-btn .spinning{animation:spin 1s linear infinite}.btn{align-items:center;border-radius:6px;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;text-decoration:none;transition:all .2s ease}.btn-analytics{background:#28a745}.btn-analytics:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.btn-analytics{align-items:center;background:#17a2b8;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;height:40px;min-width:160px;padding:8px 16px;transition:all .2s ease}.btn-analytics:hover{background:#138496;box-shadow:0 4px 8px #17a2b84d;transform:translateY(-1px)}.btn-icon{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.btn-icon-danger{color:#dc3545}.btn-icon-danger:hover{background:#f8d7da}.message{border-radius:6px;font-size:14px;gap:10px;margin-bottom:16px;padding:12px 16px;position:relative}.message-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.message-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.close-btn{cursor:pointer;opacity:.7;position:absolute;right:12px}.close-btn:hover{opacity:1}.filters-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.filters-grid{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.filter-group{align-items:center;gap:8px}.filter-select{border:1px solid #ced4da;border-radius:4px;font-size:14px;min-width:150px;padding:8px 12px}.filter-select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;max-height:90vh;max-width:600px;width:100%}.large-modal{max-width:800px}.modal-header h3{color:#333;margin:0}.modal-body{padding:24px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1/-1}.form-group label{color:#555;font-size:14px;font-weight:500;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.required-field{background-color:#fff5f5;border-color:#dc3545!important}.required-field:focus{border-color:#dc3545!important;box-shadow:0 0 0 2px #dc354540!important}.readonly-field{background-color:#f8f9fa!important;color:#6c757d!important;cursor:not-allowed}.readonly-field:focus{border-color:#ddd!important;box-shadow:none!important}.field-help{color:#6c757d;display:block;font-size:.75em;margin-top:4px}.form-group textarea{min-height:60px;resize:vertical}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;overflow-x:auto}.solicitudes-table{border-collapse:collapse;color:#000;font-size:14px;width:100%}.solicitudes-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#000;font-weight:600;padding:12px 8px;text-align:left;white-space:nowrap}.solicitudes-table td{border-bottom:1px solid #e9ecef;color:#000;padding:10px 8px;vertical-align:middle}.solicitud-row:hover{background-color:#f8f9fa}.numero-solicitud{color:#007bff;font-weight:600;min-width:120px}.proyecto-info{min-width:200px}.proyecto-details{display:flex;flex-direction:column;gap:2px}.proyecto-folio{color:#000;font-size:13px}.proyecto-nombre{color:#000;font-size:12px}.residente-info{align-items:center;color:#000;display:flex;gap:6px}.estatus-container{align-items:center;display:flex;gap:8px;position:relative}.estatus-select{-webkit-appearance:none;appearance:none;background:#fff;border:2px solid;border-radius:4px;color:#000;cursor:pointer;font-size:12px;font-weight:500;min-width:120px;padding:4px 8px}.estatus-indicator{border-radius:50%;height:8px;width:8px}.prioridad-badge{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.folios-count{text-align:center}.count-badge{background:#e9ecef;border-radius:12px;color:#000;font-size:12px;font-weight:600;padding:4px 8px}.presupuesto{color:#000;font-weight:500;text-align:right}.dias-vencimiento{align-items:center;background:#e9ecef;border-radius:4px;color:#000;display:flex;font-size:12px;font-weight:500;gap:4px;padding:2px 6px}.dias-vencimiento.urgente{background:#fff3cd;color:#856404}.dias-vencimiento.vencida{background:#f8d7da;color:#721c24}.expand-btn{align-items:center;background:none;border:none;border-radius:2px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:background-color .2s}.expand-btn:hover{background:#e9ecef}.editable-cell{border-radius:2px;cursor:pointer;padding:4px;transition:background-color .2s}.editable-cell:hover{background:#f8f9fa}.cell-input{background:#fff;border:1px solid #007bff;border-radius:2px;font-size:inherit;padding:4px 6px;width:100%}.cell-input:focus{box-shadow:0 0 0 2px #007bff40;outline:none}.folios-expanded-row{background:#f8f9fa}.folios-container{background:#fff;border:1px solid #e9ecef;border-radius:4px;margin:10px;padding:20px}.folios-container h4{align-items:center;color:#495057;display:flex;font-size:16px;gap:8px;margin:0 0 15px}.folios-table{border-collapse:collapse;color:#000;font-size:13px;table-layout:fixed;width:100%}.folios-table th{background:#e9ecef;border:1px solid #dee2e6;color:#000;font-weight:600;max-width:400px;min-width:80px;overflow:hidden;padding:8px;position:relative;resize:horizontal;text-align:left}.folios-table th:hover{cursor:col-resize}.folios-table td{border:1px solid #dee2e6;color:#000;overflow:hidden;padding:6px 8px;text-overflow:ellipsis;white-space:nowrap}.folios-table tr:nth-child(2n){background:#f8f9fa}.folios-table .totals-row{background:#e9ecef!important;border-top:2px solid #6c757d}.folios-table .totals-row td{border-top:2px solid #6c757d;font-weight:700}.no-folios{color:#6c757d;font-style:italic;padding:20px;text-align:center}.loading-container{color:#6c757d;flex-direction:column;padding:60px 20px}.loading-container,.loading-overlay{align-items:center;display:flex;justify-content:center}.loading-overlay{background:#fffc;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.spinner{animation:spin 1s linear infinite;color:#007bff}.empty-state{align-items:center;color:#6c757d;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-state h3{color:#495057;margin:16px 0 8px}.empty-state p{font-size:14px}.actions-cell{display:flex;gap:4px;justify-content:center}@media (max-width:1200px){.filters-grid{flex-wrap:wrap;gap:10px}.filter-group,.filters-grid{align-items:center;display:flex}.filter-group svg{color:#6b7280;flex-shrink:0;height:18px;margin-top:1px;vertical-align:middle;width:18px}.filter-select{font-size:14px;line-height:1.3;padding:6px 10px}}@media (max-width:768px){.solicitudes-manager{padding:10px}.solicitudes-header{flex-direction:column;gap:15px;text-align:center}.header-actions{justify-content:center;width:100%}.modal-overlay{padding:10px}.modal-content{max-height:95vh}.form-grid{grid-template-columns:1fr}.table-container{overflow-x:scroll}.solicitudes-table{min-width:1000px}}.form-group label:after{content:""}.form-group label:has(+input[required]):after,.form-group label:has(+select[required]):after{color:#dc3545;content:" *"}.solicitudes-table input,.solicitudes-table select{color:#000!important}.solicitudes-table .cell-input,.solicitudes-table .editable-cell{color:#000}.btn:focus,.estatus-select:focus,.filter-select:focus{outline:2px solid #007bff;outline-offset:2px}.btn-icon:focus{outline:2px solid #007bff;outline-offset:1px}.folios-expanded-row,.solicitud-row{transition:background-color .2s ease}.count-badge,.estatus-select,.prioridad-badge{transition:all .2s ease}.proyecto-nombre,.residente-info span{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.solicitud-row[data-urgente=true]{border-left:4px solid #ffc107}.solicitud-row[data-vencida=true]{border-left:4px solid #dc3545}.back-btn{font-size:.9rem;padding:10px 15px;transition:background-color .2s}.view-header h1{font-size:1.5rem}.view-header .solicitud-info{background:#e9ecef;border-radius:6px;color:#495057;font-size:.9rem;padding:10px 15px}.proyecto-info{font-weight:500}.folios-count-btn{border-radius:4px;justify-content:center;transition:background-color .2s;width:100%}.folios-count-btn:hover{background-color:#f8f9fa}.folios-count-btn .count-badge{background:#007bff;border-radius:12px;min-width:20px;padding:2px 8px;text-align:center}.folios-count-btn svg{color:#6c757d}.folios-count-btn:hover svg{color:#007bff}.folios-count-btn{background:#007bff;color:#fff;font-size:.9em;padding:6px 12px}.folios-count-btn:hover{background:#0056b3;box-shadow:0 2px 4px #0003;transform:translateY(-1px)}.folios-count-btn .count-badge{background:#fff3;font-weight:700}.view-header{box-shadow:0 2px 4px #0000001a;gap:15px;padding:20px}.back-btn{padding:10px 16px}.view-header h1{color:#333;font-size:1.5em}.view-header .solicitud-info{margin-left:auto}.solicitud-info .proyecto-info{background:#e9ecef;border-radius:6px;color:#6c757d;font-size:.9em;font-weight:500;padding:8px 12px}.folios-count-btn{align-items:center;background:none;border:none;border-radius:6px;color:#6c757d;cursor:pointer;display:flex;gap:6px;padding:4px 8px;transition:all .2s ease}.folios-count-btn:hover{background-color:#e9ecef;color:#007bff}.folios-count-btn .count-badge{background-color:#007bff;border-radius:10px;color:#fff;font-size:.8em;font-weight:500;padding:2px 6px}.folios-count-btn:hover .count-badge{background-color:#0056b3}.solicitudes-folios-view{background-color:#f8f9fa;min-height:100vh;padding:20px}.solicitudes-folios-view .view-header{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;gap:20px;margin-bottom:20px;padding:20px}.back-btn{border-radius:6px;font-size:.9em;transition:all .2s ease}.back-btn:hover{transform:translateX(-2px)}.solicitudes-folios-view .view-header h1{color:#333;font-size:1.5em;margin:0}.solicitudes-folios-view .solicitud-info{margin-left:auto}.solicitudes-folios-view .proyecto-info{background:#e9ecef;border-radius:6px;color:#495057;font-size:.9em;font-weight:500;padding:8px 12px}.permissions-manager{background-color:#f8f9fa;min-height:100vh;padding:2rem}.permissions-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;margin-bottom:2rem;padding:2rem}.header-content{align-items:center;display:flex;gap:1rem}.header-content svg{color:#3498db}.header-content h1{color:#2c3e50;font-size:1.8rem;margin:0}.header-content p{color:#7f8c8d;font-size:1rem;margin:.5rem 0 0}.role-selector{align-items:center;display:flex;gap:1rem}.role-selector label{color:#2c3e50;font-weight:600}.role-select{background:#fff;border:2px solid #e1e8ed;border-radius:8px;color:#2c3e50;cursor:pointer;font-size:1rem;min-width:150px;padding:.8rem 1.2rem;transition:all .3s ease}.role-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.message{align-items:center;border-radius:8px;display:flex;font-weight:500;gap:.5rem;margin-bottom:2rem;padding:1rem 1.5rem}.message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.message.warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.message.info{background-color:#cce7ff;border:1px solid #b8daff;color:#0c5460}.permissions-content{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.role-info{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:1.5rem 2rem}.role-info h3{font-size:1.3rem;margin:0}.loading{align-items:center;color:#6c757d;display:flex;font-size:1.1rem;gap:1rem;justify-content:center;padding:3rem}.spinning{animation:spin 1s linear infinite}.modules-container{padding:2rem}.module-section{margin-bottom:2.5rem}.module-header{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:1rem 1.5rem;transition:all .3s ease}.module-header:hover{background:#e9ecef}.module-header h4{align-items:center;color:#2c3e50;display:flex;font-size:1.2rem;font-weight:600;gap:.5rem;margin:0}.permissions-count{background:#3498db;border-radius:20px;color:#fff;font-size:.9rem;font-weight:600;padding:.3rem .8rem}.permissions-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-top:1.5rem}.permission-card{background:#fff;border:2px solid #e9ecef;border-radius:10px;padding:1.5rem;transition:all .3s ease}.permission-card.enabled{background:#f8fff9;border-color:#27ae60}.permission-card.disabled{background:#f8f9fa;border-color:#e9ecef}.permission-info h5{color:#2c3e50;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.permission-info p{color:#6c757d;font-size:.95rem;line-height:1.4;margin:0 0 .8rem}.permission-code{background:#e9ecef;border-radius:4px;color:#6c757d;font-family:Monaco,Consolas,monospace;font-size:.85rem;padding:.2rem .5rem}.permission-controls{margin-top:1rem}.permission-toggle{align-items:center;color:#2c3e50;cursor:pointer;display:flex;font-weight:600;gap:.8rem;margin-bottom:1rem}.permission-toggle input[type=checkbox]{display:none}.toggle-slider{background:#ccc;border-radius:24px;height:24px;position:relative;transition:.3s;width:50px}.toggle-slider:before{background:#fff;border-radius:50%;content:"";height:20px;left:2px;position:absolute;top:2px;transition:.3s;width:20px}.permission-toggle input:checked+.toggle-slider{background:#27ae60}.permission-toggle input:checked+.toggle-slider:before{transform:translateX(26px)}.advanced-controls{border-left:3px solid #27ae60;margin-top:1rem;padding-left:1rem}.checkbox-label{align-items:center;color:#6c757d;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem;margin-bottom:.8rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:16px;width:16px}.limite-monto{background:#f8f9fa;border-radius:6px;margin-top:1rem;padding:1rem}.limite-monto label{color:#2c3e50;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.monto-input{border:1px solid #e9ecef;border-radius:6px;color:#2c3e50;font-size:.95rem;padding:.6rem;width:100%}.monto-input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db1a;outline:none}.actions-bar{background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;padding:2rem}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.8rem 1.5rem;text-decoration:none;transition:all .3s ease}.btn-primary{background:#3498db}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.btn-primary:disabled{background:#bdc3c7;cursor:not-allowed}.btn-secondary{background:#95a5a6}.btn-secondary:hover:not(:disabled){background:#7f8c8d;transform:translateY(-1px)}.btn-secondary:disabled{background:#bdc3c7;cursor:not-allowed}@media (max-width:768px){.permissions-manager{padding:1rem}.permissions-header{flex-direction:column;gap:1rem;text-align:center}.permissions-grid{gap:1rem;grid-template-columns:1fr}.actions-bar,.role-selector{flex-direction:column}.role-selector{text-align:center}}@media (max-width:480px){.permissions-header{padding:1.5rem}.header-content h1{font-size:1.5rem}.modules-container,.permission-card{padding:1rem}}.folios-complete-container{display:flex;flex:none!important;flex-direction:column;height:auto;margin:0 auto;max-width:100%;min-height:auto;overflow:visible;padding:1rem}.folios-complete-header{align-items:flex-start;background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem}.header-left h1{align-items:center;color:#2c3e50;display:flex;font-size:1.5rem;gap:.5rem;margin:0 0 .5rem}.header-left p{color:#495057;font-size:.9rem;margin:0}.btn-primary,.btn-secondary,.btn-success,.header-actions{align-items:center;display:flex;gap:.5rem}.btn-primary,.btn-secondary,.btn-success{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-secondary:hover:not(:disabled){background:#545b62}.btn-success{background:#28a745;color:#fff}.btn-success:hover:not(:disabled){background:#1e7e34}.btn-primary:disabled,.btn-secondary:disabled,.btn-success:disabled{cursor:not-allowed;opacity:.6}.folios-filters-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.filters-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(5,1fr);margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;position:relative;width:100%}.filter-group label{align-items:center;color:#212529;display:flex;font-size:.85rem;font-weight:600;gap:.5rem;height:24px;margin-bottom:.5rem}.filter-group input,.filter-group select{background-color:#fff;border:1px solid #ced4da;border-radius:4px;box-sizing:border-box;color:#212529;font-size:.9rem;height:42px;padding:.75rem;transition:border-color .2s ease;width:100%}.filter-group input::placeholder{color:#495057;font-weight:500}.filter-group input:focus,.filter-group select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.multiselect-container,.multiselect-display{position:relative;width:100%}.multiselect-display{align-items:center;background-color:#fff;border:1px solid #ced4da;border-radius:4px;cursor:pointer;display:flex;min-height:42px;padding:.5rem 2rem .5rem .75rem;transition:all .2s ease}.multiselect-display:hover{border-color:#007bff}.multiselect-display.open{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.multiselect-values{align-items:center;display:flex;flex:1 1;min-height:20px}.placeholder{color:#495057;font-size:.9rem;font-weight:500}.selected-tags{display:flex;flex-wrap:wrap;width:100%}.selected-tags,.tag{align-items:center;gap:.25rem}.tag{background-color:#007bff;border-radius:12px;color:#fff;display:inline-flex;font-size:.75rem;font-weight:600;max-width:150px;padding:.2rem .5rem}.tag button{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:16px;justify-content:center;line-height:1;margin-left:.25rem;padding:0;transition:background-color .2s ease;width:16px}.tag button:hover{background-color:#fff3}.multiselect-arrow{color:#343a40;font-size:.8rem;font-weight:600;pointer-events:none;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:transform .2s ease}.multiselect-display.open .multiselect-arrow{transform:translateY(-50%) rotate(180deg)}.multiselect-dropdown{background:#fff;border:1px solid #ced4da;border-radius:0 0 4px 4px;border-top:none;box-shadow:0 4px 6px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.multiselect-dropdown::-webkit-scrollbar{width:6px}.multiselect-dropdown::-webkit-scrollbar-track{background:#f1f1f1}.multiselect-dropdown::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.multiselect-dropdown::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.multiselect-option{align-items:center;border-bottom:1px solid #f8f9fa;color:#212529;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem .75rem;transition:background-color .2s ease}.multiselect-option:last-child{border-bottom:none}.multiselect-option:hover{background-color:#f8f9fa;color:#212529}.multiselect-option.selected{background-color:#e3f2fd;color:#1565c0;font-weight:600}.multiselect-option.selected:hover{background-color:#bbdefb;color:#0d47a1}.multiselect-option input[type=checkbox]{accent-color:#007bff;height:auto;margin:0;width:auto}.multiselect-option span{color:inherit;flex:1 1;font-weight:inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filters-actions{border-top:1px solid #e9ecef;display:flex;gap:.5rem;justify-content:flex-end;padding-top:1rem}.results-info{background:#f8f9fa;border-radius:6px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:.75rem}.results-count{color:#212529;font-size:.9rem;font-weight:500}.incomplete-results{color:#dc3545;font-weight:600}.results-warning{align-items:center;background:#fff3cd;border:1px solid #ffeeba;border-radius:4px;color:#856404;display:flex;font-size:.85rem;gap:.25rem;padding:.5rem}.items-per-page{align-items:center;color:#212529;display:flex;font-size:.9rem;gap:.5rem}.items-per-page select{background-color:#fff;border:1px solid #ced4da;border-radius:4px;color:#212529;font-size:.9rem;padding:.25rem .5rem}.folios-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto;overflow-y:visible;width:100%}.folios-complete-table-wrapper{height:auto!important;max-height:none!important;overflow:visible!important;width:100%}.folios-complete-table{border-collapse:collapse;font-size:.85rem;height:auto!important;max-height:none!important;table-layout:auto;width:auto}.folios-complete-table thead{background:#f8f9fa}.folios-complete-table th{border-bottom:2px solid #dee2e6;color:#212529;font-weight:600;min-width:-webkit-fit-content;min-width:fit-content;padding:.75rem 1rem;text-align:left;-webkit-user-select:none;user-select:none;white-space:nowrap}.folios-complete-table th.sortable{cursor:pointer;transition:background-color .2s ease}.folios-complete-table th.sortable:hover{background-color:#e9ecef}.th-content{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.sort-indicators{color:#6c757d;display:flex;flex-direction:column;font-size:.6rem;gap:1px}.sort-indicator.active{color:#007bff}.folios-complete-table td{border-bottom:1px solid #e9ecef;color:#212529;padding:.75rem 1rem;vertical-align:middle;white-space:nowrap}.folio-row:hover{background-color:#f8f9fa}.folio-row:nth-child(2n){background-color:#fdfdfd}.folio-row:nth-child(2n):hover{background-color:#f1f3f4}.proyecto-cell{display:flex;flex-direction:column;gap:.25rem;min-width:200px}.proyecto-folio{color:#007bff}.proyecto-nombre{font-size:.8rem;max-width:180px}.concepto-cell,.proyecto-nombre{color:#212529;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.concepto-cell{cursor:help;max-width:300px}.money-cell{color:#28a745;font-family:Courier New,monospace;font-weight:600;min-width:100px;text-align:right}.money-cell.negative{color:#dc3545}.date-cell{color:#212529;font-size:.85rem}.code-cell{color:#6f42c1;font-family:Courier New,monospace;font-weight:600}.proyecto-folio{color:#0056b3;font-size:.8rem;font-weight:600}.status-badge{background-color:#e9ecef;border:1px solid #ced4da;border-radius:12px;color:#212529;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;min-width:100px;padding:.25rem .75rem;text-align:center;text-transform:uppercase;white-space:nowrap}.status-badge.en-elaboracion{background-color:#fff3cd;border-color:#ffeaa7;color:#856404;min-width:120px;text-align:center}.status-badge.en-espera{background-color:#d1ecf1;border-color:#bee5eb;color:#0c5460}.status-badge.en-cotizacion{background-color:#cce5ff;border-color:#99d6ff;color:#004085}.status-badge.en-supervision{background-color:#e2e3e5;border-color:#d6d8db;color:#383d41}.status-badge.en-compra{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.status-badge.finalizada{background-color:#d1f2eb;border-color:#c3e6cb;color:#00695c}.status-badge.rechazada{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.status-badge.cancelada{background-color:#e2e3e5;border-color:#d6d8db;color:#383d41}.priority-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase;white-space:nowrap}.priority-badge.baja{background-color:#e2e3e5;color:#383d41}.priority-badge.media{background-color:#fff3cd;color:#856404}.priority-badge.alta{background-color:#ffccb3;color:#d63384}.priority-badge.urgente{background-color:#f8d7da;color:#721c24}.empty-state,.error-state,.loading-state{align-items:center;color:#495057;display:flex;flex-direction:column;height:auto;justify-content:center;min-height:200px;padding:3rem}.loading-state svg.spinning{animation:spin 1s linear infinite}.error-state{color:#721c24}.empty-state h3{color:#212529;margin:1rem 0 .5rem}.empty-state p{margin:0}.permission-denied{align-items:center;color:#495057;display:flex;flex-direction:column;height:auto;justify-content:center;min-height:200px;padding:3rem;text-align:center}.permission-denied h3{color:#212529;margin:1rem 0 .5rem}@media (max-width:768px){.folios-complete-container{padding:.5rem}.folios-complete-header{align-items:stretch;flex-direction:column;gap:1rem}.header-actions{justify-content:flex-start}.filters-grid{grid-template-columns:1fr}.results-info{align-items:flex-start;flex-direction:column;gap:.5rem}.folios-complete-table{font-size:.8rem}.folios-complete-table td,.folios-complete-table th{padding:.5rem .25rem}.selected-tags{max-height:60px;overflow-y:auto}.tag{font-size:.7rem;max-width:120px}.multiselect-dropdown{max-height:150px}.multiselect-option{font-size:.85rem;padding:.75rem .5rem}}.dashboard-content:has(.folios-complete-container){height:auto!important;max-height:none!important;overflow:visible!important}.total-row{background-color:#f5f5f5;border-top:2px solid #ccc}.total-row td{font-size:15px;padding:10px}.dashboard-container{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;min-height:100vh}.dashboard-topbar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;padding:12px 24px}.topbar-left .topbar-title{color:#2c3e50;font-size:1.5rem;font-weight:700;margin:0}.topbar-right{align-items:center;display:flex;gap:16px}.user-info{align-items:flex-end;display:flex;flex-direction:column;text-align:right}.user-greeting{color:#2c3e50;font-size:.9rem;font-weight:600}.user-role{color:#6c757d;font-size:.8rem;font-weight:500;text-transform:uppercase}.user-menu-container{position:relative}.user-avatar{align-items:center;background:#667eea;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.user-avatar:hover{background:#5a6fd8;transform:scale(1.05)}.user-dropdown{background:#fff;border:1px solid #0000001a;border-radius:8px;box-shadow:0 10px 30px #00000026;margin-top:8px;min-width:240px;position:absolute;right:0;top:100%;z-index:1000}.dropdown-header{padding:16px}.user-details{display:flex;flex-direction:column;gap:4px}.user-details strong{color:#2c3e50;font-size:.95rem}.user-details small{color:#6c757d;font-size:.8rem}.user-role-badge{align-self:flex-start;background:#e3f2fd;border-radius:12px;color:#1565c0;font-size:.75rem!important;font-weight:500;margin-top:4px;padding:2px 8px;text-transform:uppercase}.dropdown-divider{background:#e9ecef;height:1px;margin:0}.dropdown-item{align-items:center;background:none;border:none;color:#495057;cursor:pointer;display:flex;font-size:.9rem;gap:8px;padding:12px 16px;text-align:left;transition:background .2s ease;width:100%}.dropdown-item:hover{background:#f8f9fa}.logout-btn{color:#dc3545}.logout-btn:hover{background:#fff5f5}.dashboard-content{flex:1 1;padding:20px}.permissions-modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.permissions-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:600px;overflow:hidden;width:100%}.modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#2c3e50;font-size:1.4rem;margin:0}.modal-close{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;font-size:1.5rem;padding:4px;transition:background .2s ease}.modal-close:hover{background:#dee2e6}.modal-content{max-height:50vh;overflow-y:auto;padding:24px}.user-summary{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;margin-bottom:20px;padding:16px}.user-summary p{color:#495057;margin:8px 0}.permissions-list h3{color:#2c3e50;font-size:1.1rem;margin-bottom:16px}.permissions-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.permission-item{align-items:center;border:1px solid #e9ecef;border-radius:8px;display:flex;gap:12px;padding:12px;transition:all .2s ease}.permission-item.allowed{background:#f8fff9;border-color:#d4edda}.permission-item.denied{background:#fff5f5;border-color:#f8d7da}.permission-status{font-size:1.2rem}.permission-details{display:flex;flex-direction:column;gap:2px}.permission-name{color:#2c3e50;font-size:.9rem;font-weight:500}.permission-module{color:#6c757d;font-size:.75rem;font-weight:500;text-transform:uppercase}.loading-permissions{color:#6c757d;padding:40px 20px;text-align:center}.modal-footer{background:#f8f9fa;border-top:1px solid #e9ecef;padding:16px 24px;text-align:right}.btn-secondary{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:background .2s ease}.btn-secondary:hover{background:#5a6268}.view-header{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;gap:20px;margin-bottom:20px;padding:15px 20px}.back-btn,.view-header{align-items:center;display:flex}.back-btn{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;gap:8px;padding:8px 16px;transition:background .3s}.back-btn:hover{background:#5a6268}.view-header h1{color:#2c3e50;font-size:24px;margin:0}.dashboard-home{margin:0 auto;max-width:1200px}.dashboard-header{color:#fff;margin-bottom:40px;text-align:center}.dashboard-header h1{font-size:3rem;margin-bottom:10px;text-shadow:2px 2px 4px #0000004d}.dashboard-header p{font-size:1.2rem;opacity:.9}.dashboard-options{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:40px}.dashboard-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;cursor:pointer;padding:30px;text-align:center;transition:all .3s ease}.dashboard-card:hover{box-shadow:0 20px 40px #00000026;transform:translateY(-5px)}.card-icon{color:#667eea;margin-bottom:20px}.dashboard-card h2{color:#2c3e50;font-size:1.5rem;margin-bottom:15px}.dashboard-card p{color:#6c757d;font-size:1rem;line-height:1.5;margin-bottom:20px}.card-features{display:flex;flex-direction:column;gap:8px;text-align:left}.card-features span{align-items:center;color:#28a745;display:flex;font-size:.9rem;gap:8px}.card-features span:before{content:"✓";font-weight:700}.dashboard-info{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:40px}.info-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;padding:20px}.info-section h3{color:#fff;font-size:1.2rem;margin-bottom:15px}.info-section p{line-height:1.6;opacity:.9}.perfiles-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:40px}.perfiles-info{color:#495057;text-align:center}.perfiles-info p{color:#6c757d;font-size:16px;margin-bottom:40px}.coming-soon{align-items:center;display:flex;flex-direction:column;gap:20px;padding:60px 20px}.coming-soon svg{color:#6c757d;opacity:.6}.coming-soon h2{color:#495057;font-size:28px;margin:0}.coming-soon p{color:#6c757d;font-size:16px;margin:0;opacity:.8}@media (max-width:768px){.dashboard-topbar{padding:10px 16px}.topbar-left .topbar-title{font-size:1.2rem}.user-info{display:none}.user-dropdown{min-width:200px;right:-16px}.dashboard-content{padding:15px}.dashboard-header h1{font-size:2rem}.dashboard-options{gap:20px;grid-template-columns:1fr}.dashboard-card{padding:20px}.view-header{align-items:flex-start;flex-direction:column;gap:10px}.view-header h1{font-size:20px}}.no-modules-message{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin:40px auto;max-width:500px;padding:60px 40px;text-align:center}.no-modules-message .message-icon{color:#6c757d;margin-bottom:20px;opacity:.7}.no-modules-message h3{color:#495057;font-size:1.4rem;font-weight:600;margin-bottom:16px}.no-modules-message p{color:#6c757d;font-size:1rem;line-height:1.5;margin:0}:root{--bg:#0b1020;--card:#ffffff0f;--card-strong:#ffffff1f;--text:#f5f7fb;--muted:#b6bfd3;--primary:#6aa2ff;--primary-600:#4b89f9;--danger:#ff6b6b;--success:#30d475;--ring:#6aa2ff59}#root,body,html{background:radial-gradient(1200px 800px at 10% 10%,#16223f 0,#0b1020 50%,#070b15 100%);color:#f5f7fb;color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Apple Color Emoji,Segoe UI Emoji;height:100%}.auth-page{display:grid;min-height:100%;padding:clamp(16px,4vw,40px);place-items:center}.auth-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;justify-content:center;margin:0 auto;max-width:450px;width:min(1080px,100%)}@media (max-width:900px){.auth-grid{grid-template-columns:1fr}}.auth-hero{background:linear-gradient(160deg,#6aa2ff26,#30d4751f);border:1px solid #ffffff1f;border-radius:20px;min-height:360px;overflow:hidden;padding:clamp(20px,5vw,36px);position:relative}.hero-blur{background:radial-gradient(closest-side,#6aa2ff59,#0000 70%);filter:blur(30px);height:340px;inset:-60px -40px auto auto;pointer-events:none;position:absolute;width:340px}.brand{align-items:center;display:flex;gap:14px;margin-bottom:16px}.brand-logo{background:#ffffff1a;border:1px solid #ffffff2e;border-radius:12px;display:grid;font-weight:700;height:46px;letter-spacing:.5px;place-items:center;width:46px}.brand-text h1{font-size:clamp(22px,3vw,28px);margin:0 0 4px}.brand-text p{margin:0}.benefits,.brand-text p{color:#b6bfd3;color:var(--muted)}.benefits{list-style:none;margin:20px 0 0;padding:0}.benefits li{margin:8px 0}.auth-card{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#ffffff0f;background:var(--card);border:1px solid #ffffff1f;border-radius:20px;box-shadow:0 20px 60px #00000059;display:flex;flex-direction:column;gap:18px;padding:clamp(18px,4vw,28px)}.auth-header h2{font-size:clamp(20px,3vw,26px);margin:0 0 4px}.muted{color:#b6bfd3;color:var(--muted);font-size:14px}.form{grid-gap:14px;display:grid;gap:14px}.field{grid-gap:6px;display:grid;gap:6px}.field label{color:#b6bfd3;color:var(--muted);font-size:13px}.field input{background:#0a0e1873;border:1px solid #ffffff29;border-radius:12px;color:#f5f7fb;color:var(--text);outline:none;padding:12px 14px;transition:box-shadow .15s ease,border-color .15s ease,transform .05s ease;width:100%}.field input::placeholder{color:#8b95ac}.field input:focus{border-color:#6aa2ff;border-color:var(--primary);box-shadow:0 0 0 6px #6aa2ff59;box-shadow:0 0 0 6px var(--ring)}.input-with-action{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:1fr auto}.ghost{background:#0000;border:1px dashed #ffffff2e;border-radius:10px;color:#6aa2ff;color:var(--primary);cursor:pointer;padding:10px 12px}.ghost:hover{border-color:#6aa2ff;border-color:var(--primary)}.btn{border:none;border-radius:12px;cursor:pointer;font-weight:600;padding:12px 16px}.btn.primary{background:linear-gradient(180deg,#6aa2ff,#4b89f9);background:linear-gradient(180deg,var(--primary),var(--primary-600));box-shadow:0 10px 24px #6aa2ff59;color:#fff;transition:transform .05s ease,filter .15s ease}.btn.primary:hover{filter:brightness(1.05)}.btn.primary:active{transform:translateY(1px)}.btn:disabled{cursor:not-allowed;opacity:.6}.alert{align-items:center;border:1px solid #ffffff1f;border-radius:12px;display:flex;font-size:14px;gap:10px;padding:10px 12px}.alert .alert-dot{border-radius:999px;display:inline-block;height:8px;width:8px}.alert.error{background:#ff6b6b1a;color:#ffd1d1}.alert.error .alert-dot{background:#ff6b6b;background:var(--danger)}.alert.success{background:#30d4751f;color:#d2ffe6}.alert.success .alert-dot{background:#30d475;background:var(--success)}.auth-footer{margin-top:6px;text-align:center}.loader{animation:spin .8s linear infinite;border:2px solid #fff6;border-radius:999px;border-top-color:#fff;display:inline-block;height:18px;vertical-align:middle;width:18px}.slide-up{animation:slideUp .35s ease both}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}*{box-sizing:border-box;margin:0;padding:0}.App{background-color:#f8f9fa;min-height:100vh}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}
/*# sourceMappingURL=main.23a8396a.css.map*/