*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f0f2f5;color:#333}#app{height:100%}.layout-wrapper{display:flex;height:100vh;overflow:hidden}.layout-sidebar{width:260px;min-width:260px;background:linear-gradient(180deg,#1e3a5f,#0d1b2a);color:#fff;display:flex;flex-direction:column;overflow-y:auto;z-index:1000;transition:transform .3s ease}@media (max-width: 991px){.layout-sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%)}.layout-sidebar.sidebar-active{transform:translate(0)}}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000073;z-index:999}@media (max-width: 991px){.sidebar-overlay.sidebar-overlay--visible{display:block}}.sidebar-header{padding:24px 20px 16px;text-align:center;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-header img{width:130px;margin-bottom:6px}.sidebar-header h2{font-size:15px;font-weight:600;color:#cbd5e1;letter-spacing:1px}.sidebar-user{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:12px}.sidebar-user .avatar{width:42px;height:42px;border-radius:50%;background:#c0392b;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff}.sidebar-user .user-info .name{font-size:14px;font-weight:600;color:#e2e8f0}.sidebar-user .user-info .role{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.sidebar-menu{padding:8px 0;flex:1}.sidebar-menu .menu-label{padding:18px 20px 6px;font-size:10px;text-transform:uppercase;color:#64748b;letter-spacing:1px;font-weight:700}.sidebar-menu .menu-item{display:flex;align-items:center;gap:12px;padding:11px 20px;color:#94a3b8;text-decoration:none;font-size:13px;font-weight:500;transition:all .15s ease;cursor:pointer;border-left:3px solid transparent}.sidebar-menu .menu-item:hover{background:#ffffff0f;color:#e2e8f0}.sidebar-menu .menu-item.router-link-exact-active,.sidebar-menu .menu-item.active{background:#c0392b26;color:#f87171;border-left-color:#c0392b}.sidebar-menu .menu-item i{width:20px;text-align:center;font-size:15px}.layout-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.layout-topbar{height:56px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.layout-topbar h3{font-size:17px;font-weight:600;color:#1e293b}@media (max-width: 575px){.layout-topbar{padding:0 12px}}.topbar-hamburger{display:none;background:none;border:none;color:#1e293b;font-size:20px;cursor:pointer;padding:6px;margin-right:8px;border-radius:6px}.topbar-hamburger:hover{background:#f0f2f5}@media (max-width: 991px){.topbar-hamburger{display:inline-flex;align-items:center;justify-content:center}}.topbar-email{font-size:12px;color:#64748b}@media (max-width: 575px){.topbar-email{display:none}}.layout-content{flex:1;padding:20px 24px;overflow-y:auto}@media (max-width: 575px){.layout-content{padding:12px}}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#0d1b2a,#c0392b);padding:16px}.login-card{background:#fff;border-radius:16px;padding:44px 40px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000059;text-align:center}.login-card img{width:150px;margin-bottom:12px}.login-card h1{font-size:24px;color:#1e293b;margin-bottom:4px;font-weight:700}.login-card .subtitle{color:#64748b;margin-bottom:32px;font-size:13.5px}.login-card .field-label{color:#374151}.login-card .p-inputtext{padding:.85rem 1rem!important;font-size:14.5px!important}.login-card .p-password,.login-card .p-password .p-inputtext{width:100%}.login-card .p-button{padding:.85rem 1.5rem!important;font-size:15px!important;font-weight:600;border-radius:8px!important;margin-top:8px}@media (max-width: 575px){.login-card{padding:32px 22px}}.card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 3px #00000014}.section-heading{color:#1e293b;font-size:16px;font-weight:600}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:24px}@media (max-width: 575px){.dashboard-cards{grid-template-columns:1fr}}@media (min-width: 576px) and (max-width: 767px){.dashboard-cards{grid-template-columns:repeat(2,1fr)}}.stat-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 3px #00000014;border-left:4px solid #e5e7eb}.stat-card .stat-value{font-size:30px;font-weight:700;color:#1e293b}.stat-card .stat-label{font-size:12px;color:#6b7280;margin-top:2px;font-weight:500}.stat-card.card-red{border-left-color:#c0392b}.stat-card.card-green{border-left-color:#27ae60}.stat-card.card-yellow{border-left-color:#f39c12}.stat-card.card-blue{border-left-color:#2980b9}.stat-card.card-purple{border-left-color:#8e44ad}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}.status-badge.pendiente{background:#fdebd0;color:#935116}.status-badge.aprobado{background:#d5f5e3;color:#1e8449}.status-badge.rechazado{background:#fadbd8;color:#922b21}.status-tag{font-size:11px!important;font-weight:600!important}.status-tag.p-tag-warning{background:#fdebd0!important;color:#935116!important}.status-tag.p-tag-success{background:#d5f5e3!important;color:#1e8449!important}.status-tag.p-tag-danger{background:#fadbd8!important;color:#922b21!important}.field-label{display:block;margin-bottom:8px;font-size:13.5px;font-weight:600;color:#b8860b;letter-spacing:.1px}.p-inputtext{padding:.75rem .875rem!important;font-size:14px!important;border-radius:8px!important;border:1.5px solid #d1d5db!important;transition:border-color .2s ease,box-shadow .2s ease!important}.p-inputtext:enabled:hover{border-color:#9ca3af!important}.p-inputtext:enabled:focus{border-color:#c0392b!important;box-shadow:0 0 0 3px #c0392b1a!important}.p-inputtext::placeholder{color:#9ca3af;font-size:13.5px}.p-dropdown{border-radius:8px!important;border:1.5px solid #d1d5db!important;transition:border-color .2s ease,box-shadow .2s ease!important}.p-dropdown .p-dropdown-label{padding:.75rem .875rem!important;font-size:14px!important}.p-dropdown:not(.p-disabled):hover{border-color:#9ca3af!important}.p-dropdown:not(.p-disabled).p-focus{border-color:#c0392b!important;box-shadow:0 0 0 3px #c0392b1a!important}.p-multiselect{border-radius:8px!important;border:1.5px solid #d1d5db!important;transition:border-color .2s ease,box-shadow .2s ease!important}.p-multiselect .p-multiselect-label{padding:.75rem .875rem!important;font-size:14px!important}.p-multiselect:not(.p-disabled):hover{border-color:#9ca3af!important}.p-multiselect:not(.p-disabled).p-focus{border-color:#c0392b!important;box-shadow:0 0 0 3px #c0392b1a!important}.p-password .p-inputtext{padding-right:2.75rem!important}textarea.p-inputtextarea{padding:.75rem .875rem!important;font-size:14px!important;border-radius:8px!important;border:1.5px solid #d1d5db!important;transition:border-color .2s ease,box-shadow .2s ease!important;resize:vertical}textarea.p-inputtextarea:enabled:hover{border-color:#9ca3af!important}textarea.p-inputtextarea:enabled:focus{border-color:#c0392b!important;box-shadow:0 0 0 3px #c0392b1a!important}.form-field{margin-bottom:1.25rem}.field-error .p-inputtext,.field-error .p-dropdown,.field-error .p-multiselect,.field-error .p-password input,.p-invalid.p-inputtext,.p-invalid.p-dropdown,.p-invalid.p-multiselect{border-color:#e74c3c!important}.p-invalid.p-inputtext:enabled:focus,.p-invalid.p-inputtext:not(.p-disabled).p-focus,.p-invalid.p-dropdown:enabled:focus,.p-invalid.p-dropdown:not(.p-disabled).p-focus,.p-invalid.p-multiselect:enabled:focus,.p-invalid.p-multiselect:not(.p-disabled).p-focus{box-shadow:0 0 0 3px #e74c3c26!important}.field-error-message{color:#e74c3c;font-size:12px;margin-top:6px;display:block;font-weight:500}.form-card{max-width:900px;padding:28px 32px}@media (max-width: 575px){.form-card{padding:20px 16px}}.form-section{padding-top:20px;margin-top:8px;border-top:1px solid #f0f0f0}.form-section-title{font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.filter-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.filter-bar .p-inputtext,.filter-bar .p-dropdown{min-width:220px}.filter-bar .p-input-icon-left>i{top:50%;transform:translateY(-50%);margin-top:0}.filter-bar .p-input-icon-left>.p-inputtext{padding-left:2.5rem!important}@media (max-width: 575px){.filter-bar{flex-direction:column}.filter-bar .p-inputtext,.filter-bar .p-dropdown,.filter-bar .p-input-icon-left{width:100%!important;min-width:0}}.btn-recibir{background:#1abc9c!important;border-color:#1abc9c!important;color:#fff!important}.btn-rechazar{background:#e75c8c!important;border-color:#e75c8c!important;color:#fff!important}.btn-verificado{background:#f1c40f!important;border-color:#f1c40f!important;color:#333!important}.approval-actions{display:flex;gap:4px}@media (max-width: 767px){.approval-actions{flex-direction:column;gap:6px}.approval-actions .p-button{width:100%;justify-content:center}}.tag-programa{display:inline-block;background:#eaecee;padding:3px 10px;border-radius:4px;font-size:11px;margin:2px;color:#333}.tag-herramienta{display:inline-block;background:#d6eaf8;padding:3px 10px;border-radius:4px;font-size:11px;margin:2px;color:#1a5276}.tiempo-text{font-size:12px;color:#27ae60;font-weight:500}.detail-table{width:100%;border-collapse:collapse}.detail-table tr{border-bottom:1px solid #f0f0f0}.detail-table td{padding:10px 0;font-size:13px}.detail-table .detail-table__label{color:#6b7280;font-weight:600;width:40%}@media (max-width: 575px){.detail-table tr{display:flex;flex-direction:column;padding:8px 0}.detail-table td{padding:2px 0}.detail-table .detail-table__label{width:100%;font-size:12px}}.detail-section-label{font-size:12px;color:#6b7280;font-weight:600}.text-placeholder{color:#ccc}.empty-state-text{color:#94a3b8;text-align:center;padding:12px}.timeline-step{display:flex;gap:12px;margin-bottom:12px}.timeline-dot-col{display:flex;flex-direction:column;align-items:center}.timeline-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0;background:#bdc3c7}.timeline-dot--aprobado{background:#27ae60}.timeline-dot--rechazado{background:#e74c3c}.timeline-dot--pendiente{background:#bdc3c7}.timeline-dot i{font-size:13px}.timeline-connector{width:2px;flex:1;min-height:16px;background:#e5e7eb;margin-top:4px}.timeline-content{flex:1;padding-bottom:4px}.timeline-role{font-weight:600;font-size:13px;color:#1e293b}.timeline-user{font-size:12px;color:#6b7280;margin-top:4px}.timeline-user i{font-size:11px}.timeline-comment{font-size:12px;color:#374151;margin-top:4px;background:#f8f9fa;padding:6px 10px;border-radius:6px;border-left:3px solid #e5e7eb}.timeline-date{font-size:11px;color:#9ca3af;margin-top:4px}.timeline-empty{text-align:center;padding:12px;color:#9ca3af}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:24px}:root{--primary-color: #ef4444;--primary-color-text: #ffffff}.p-button{background:#ef4444;border-color:#ef4444}.p-button:hover{background:#dc2626;border-color:#dc2626}.p-button.p-button-danger{background:#c0392b;border-color:#c0392b}.p-button.p-button-secondary,.p-button.p-button-text{background:transparent;border-color:transparent;color:#64748b}.p-button.p-button-outlined{background:transparent;color:#64748b;border-color:#e5e7eb}.p-datatable .p-datatable-thead>tr>th{background:#f8f9fa;font-weight:600;font-size:12px;text-transform:uppercase;color:#6b7280;letter-spacing:.3px}.p-datatable .p-datatable-tbody>tr>td{font-size:13px}.p-datatable.p-datatable-responsive-stack .p-datatable-tbody>tr>td .p-column-title{font-weight:600;color:#6b7280;font-size:12px;text-transform:uppercase;min-width:120px}.operacion-item{padding:14px 0;border-bottom:1px solid #f0f0f0}.operacion-item:last-child{border-bottom:none}.operacion-item .operacion-title{font-weight:600;font-size:14px;color:#1e293b}.operacion-item .operacion-meta{font-size:12px;color:#6b7280;margin-top:3px}.operacion-item .operacion-tiempo{font-size:12px;color:#94a3b8}@media (max-width: 575px){.operacion-item.flex{flex-direction:column;gap:6px}.operacion-item.flex .text-right{text-align:left}}
