:root{--sidebar-width: 260px;--header-height: 70px}html{height:100%;margin:0;padding:0;box-sizing:border-box}*,*:before,*:after{margin:0;padding:0;box-sizing:inherit}body{margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#f8f9fa;min-height:100vh}.btn-primary-custom{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);color:var(--primary-color);border:none;border-radius:10px;padding:.9rem 1.5rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #d4af374d}.btn-primary-custom:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%)}.btn-primary-custom:active{transform:translateY(0)}.link-primary-red{color:var(--primary-color);text-decoration:none;transition:all .3s ease}.link-primary-red:hover{color:var(--accent-color);text-decoration:underline}.alert-custom{border-radius:10px;border:none;padding:.9rem 1rem;margin-bottom:1.5rem}.text-muted-custom{color:#6c757d}.bg-light-custom{background:linear-gradient(to bottom,#f8f9fa,#e9ecef)}.form-control-custom{border:2px solid #e9ecef!important;border-radius:8px!important;padding:.65rem 1rem!important;font-size:.95rem!important;transition:all .3s ease!important;background-color:#fff!important}.form-control-custom:focus{border-color:var(--secondary-color)!important;box-shadow:0 0 0 .2rem #d4af3726!important;outline:none!important}.form-control-custom:focus-visible{outline:none!important}.form-select-custom{border:2px solid #e9ecef!important;border-radius:8px!important;padding:.65rem 1rem!important;font-size:.95rem!important;transition:all .3s ease!important;background-color:#fff!important}.form-select-custom:focus{border-color:var(--secondary-color)!important;box-shadow:0 0 0 .2rem #d4af3726!important;outline:none!important}.form-select-custom option{padding:.75rem}.form-select-custom option:checked{background-color:var(--secondary-color)!important;color:var(--primary-color)!important;font-weight:600}.form-label{color:#495057;font-weight:600;font-size:.9rem;margin-bottom:.5rem;display:flex;align-items:center}.form-label i{color:var(--secondary-color)}.password-input-wrapper{position:relative}.password-toggle-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);cursor:pointer;color:#6c757d;font-size:1.2rem;transition:color .3s ease}.password-toggle-icon:hover{color:var(--secondary-color)}.form-control.is-invalid,.form-control-custom.is-invalid,.form-select-custom.is-invalid{border-color:#dc3545!important}.form-control.is-invalid:focus,.form-control-custom.is-invalid:focus,.form-select-custom.is-invalid:focus{border-color:#dc3545!important;box-shadow:0 0 0 .2rem #dc354526!important}.form-control.is-valid,.form-control-custom.is-valid,.form-select-custom.is-valid{border-color:#28a745!important}.form-control.is-valid:focus,.form-control-custom.is-valid:focus,.form-select-custom.is-valid:focus{border-color:#28a745!important;box-shadow:0 0 0 .2rem #28a74526!important}.form-control-custom:disabled,.form-select-custom:disabled{background-color:#e9ecef!important;cursor:not-allowed;opacity:.7}@media(max-width:768px){.form-control-custom,.form-select-custom{font-size:.9rem!important;padding:.6rem .9rem!important}}.user-search-wrapper{position:relative;width:100%}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#6c757d;font-size:1.1rem;pointer-events:none;z-index:5}#userSearch{padding-left:2.75rem!important}.user-dropdown-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid var(--secondary-color);border-top:none;border-radius:0 0 8px 8px;max-height:400px;overflow-y:auto;z-index:1000;box-shadow:0 4px 12px #00000026}.user-dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f1f3f5}.user-dropdown-item:last-child{border-bottom:none}.user-dropdown-item:hover{background-color:#f8f9fa;padding-left:1.25rem}.user-avatar-mini{width:40px;height:40px;border-radius:50%;border:2px solid var(--secondary-color);object-fit:cover;flex-shrink:0}.user-dropdown-item .user-info{flex:1;min-width:0}.user-dropdown-item .user-name{font-weight:600;color:var(--primary-color);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-item .user-email{font-size:.8rem;color:#6c757d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-badge{padding:.25rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600;color:#fff;white-space:nowrap;flex-shrink:0}.user-dropdown-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;color:#6c757d;text-align:center}.user-dropdown-empty i{font-size:2rem;margin-bottom:.5rem;opacity:.5}.user-dropdown-empty p{margin:0;font-size:.9rem}.user-dropdown-list::-webkit-scrollbar{width:6px}.user-dropdown-list::-webkit-scrollbar-track{background:#f1f3f5;border-radius:0 0 8px}.user-dropdown-list::-webkit-scrollbar-thumb{background:var(--secondary-color);border-radius:3px}.user-dropdown-list::-webkit-scrollbar-thumb:hover{background:var(--secondary-color)}@media(max-width:768px){.user-dropdown-list{max-height:300px}.user-dropdown-item{padding:.6rem .75rem}.user-avatar-mini{width:35px;height:35px}.user-dropdown-item .user-name{font-size:.9rem}.user-dropdown-item .user-email{font-size:.75rem}}.login-body{padding:2.5rem 2rem 2rem}.login-container{width:100%;max-width:480px;position:relative;z-index:1}.login-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0006;overflow:hidden;animation:none}.input-group-icon{position:relative;display:block;width:100%}.input-group-icon .form-control-custom{padding-left:3rem!important;padding-right:1rem!important}.input-group-icon .form-control-custom[type=password],.input-group-icon .form-control-custom[type=text]:has(~.password-toggle){padding-right:3rem}.input-group-icon>i.bi:not(.password-toggle){position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#6c757d;font-size:1.1rem;z-index:10;transition:color .3s ease;pointer-events:none}.input-group-icon .form-control-custom:focus~i.bi:not(.password-toggle){color:var(--secondary-color)}.input-group-icon>i.bi.password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#6c757d;cursor:pointer;font-size:1.1rem;transition:color .3s ease;z-index:10}.input-group-icon>i.bi.password-toggle:hover{color:var(--primary-color)}.btn-source-toggle{background:#fff;color:#495057;border:2px solid #dee2e6;border-radius:8px;padding:.55rem 1.25rem;font-weight:600;font-size:.9rem;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-source-toggle:hover{border-color:var(--secondary-color);color:var(--primary-color)}.btn-source-toggle.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-source-toggle.active i{color:var(--secondary-color)}.doc-reference-chip{display:inline-flex;align-items:center;gap:.4rem;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:.35rem .75rem;font-size:.85rem}.doc-reference-chip i{color:var(--secondary-color)}.ref-label{color:#6c757d;font-weight:600}.ref-value{color:var(--primary-color);font-weight:700}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;margin-bottom:1.5rem}.form-check{display:flex;align-items:center;gap:.5rem}.form-check-input{width:1.2rem;height:1.2rem;margin:0;border:2px solid #dee2e6;cursor:pointer;flex-shrink:0}.form-check-input:checked{background-color:var(--secondary-color);border-color:var(--secondary-color)}.form-check-input:focus{box-shadow:0 0 0 .2rem #d4af3726}.form-check-label{color:#6c757d;font-size:.9rem;cursor:pointer;user-select:none;margin:0}.forgot-password{color:var(--primary-color);text-decoration:none;font-size:.9rem;font-weight:600;transition:all .3s ease}.forgot-password:hover{color:var(--accent-color);text-decoration:underline}.login-btn{width:100%;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);color:var(--primary-color);border:none;border-radius:10px;padding:.9rem 1.5rem;font-size:1.05rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #d4af374d;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%)}.login-btn:active{transform:translateY(0)}.login-btn i{font-size:1.2rem;transition:transform .3s ease}.login-btn:hover i{transform:translate(5px)}.login-btn.loading{position:relative;color:transparent;pointer-events:none}.login-btn.loading:after{content:"";position:absolute;width:20px;height:20px;top:50%;left:50%;margin-left:-10px;margin-top:-10px;border:3px solid var(--primary-color);border-radius:50%;border-top-color:transparent;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-body .validation-message{color:#dc3545;font-size:.875rem;margin-top:.25rem;display:block}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);box-shadow:0 2px 10px #0000001a;z-index:1030;display:flex;align-items:center;justify-content:space-between;padding:0 2rem}.header-brand{color:#fff;font-size:1.5rem;font-weight:600;text-decoration:none;display:flex;align-items:center;gap:.75rem;transition:all .3s ease;flex-shrink:1;min-width:0}.header-brand:hover{transform:translateY(-2px)}.header-brand i{color:var(--secondary-color);font-size:1.75rem}.header-brand .brand-logo{width:119px;height:50px;object-fit:contain;background:var(--secondary-color);padding:.5rem;border-radius:8px;box-shadow:0 2px 8px #d4af3766;transition:all .3s ease;flex-shrink:0}.header-brand:hover .brand-logo{box-shadow:0 4px 12px #d4af3799}.header-user-section{display:flex;align-items:center;gap:1.25rem;flex-shrink:0}.logout-btn{background-color:var(--secondary-color);color:var(--primary-color);border:none;padding:.5rem 1.25rem;border-radius:6px;font-weight:600;font-size:.9rem;transition:all .3s ease;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;flex-shrink:0}.logout-btn:hover{background-color:var(--secondary-color);transform:translateY(-2px);box-shadow:0 4px 8px #d4af374d}.user-name{color:#fff;font-weight:500;font-size:.95rem}.user-avatar{width:45px;height:45px;border-radius:50%;border:3px solid var(--secondary-color);object-fit:cover;cursor:pointer;transition:transform .3s ease;flex-shrink:0}.user-avatar:hover{transform:scale(1.1)}.sidebar{position:fixed;top:var(--header-height);left:0;width:var(--sidebar-width);height:calc(100vh - var(--header-height));background:var(--primary-color);overflow-y:auto;transition:all .3s ease;z-index:1020}.sidebar.collapsed{left:calc(-1 * var(--sidebar-width))}.sidebar-nav{padding:1.5rem 0}.nav-section-title{color:var(--secondary-color);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:.5rem 1.5rem;margin:1rem 0 .5rem;opacity:.9}.nav-item{margin:.25rem 0}.nav-link{color:#fffc;padding:.9rem 1.5rem;display:flex;align-items:center;gap:1rem;text-decoration:none;transition:all .3s ease;border-left:4px solid transparent;font-size:.95rem}.nav-link:hover{background-color:#ffffff1a;color:#fff;border-left-color:var(--secondary-color)}.nav-link.active{background-color:#d4af3726;color:#fff;border-left-color:var(--secondary-color);font-weight:600}.nav-link i{font-size:1.25rem;width:24px;text-align:center}.nav-link.has-submenu{position:relative;cursor:pointer}.nav-link.has-submenu .submenu-arrow{position:absolute;right:1.5rem;transition:transform .3s ease;font-size:.9rem}.nav-link.has-submenu.expanded .submenu-arrow{transform:rotate(180deg)}.submenu{max-height:0;overflow:hidden;transition:max-height .4s ease;background-color:#00000026}.submenu.show{max-height:700px}.submenu .nav-link{padding:.75rem 1.5rem .75rem 3.5rem;font-size:.9rem;border-left:4px solid transparent}.submenu .nav-link:hover{background-color:#ffffff14;border-left-color:var(--secondary-color)}.submenu .nav-link.active{background-color:#d4af371f;border-left-color:var(--secondary-color)}.submenu .nav-link i{font-size:1rem}.main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:2rem;transition:margin-left .3s ease;min-height:calc(100vh - var(--header-height))}.main-content.expanded{margin-left:0}.sidebar-toggle{position:fixed;top:calc(var(--header-height) + 1rem);left:calc(var(--sidebar-width) - 20px);width:40px;height:40px;background:var(--secondary-color);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1025;transition:all .3s ease;box-shadow:0 2px 10px #00000026}.sidebar-toggle.collapsed{left:-20px}.sidebar-toggle:hover{background:var(--secondary-color);transform:scale(1.1)}.sidebar-toggle i{color:var(--primary-color);font-size:1.25rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:3px solid var(--primary-color)}.page-title{color:var(--primary-color);font-size:2rem;font-weight:700;margin:0;display:flex;align-items:center;gap:1rem}.page-title:focus{outline:none;box-shadow:none}.page-title i{color:var(--secondary-color);font-size:2rem}.breadcrumb{background:none;padding:0;margin:.5rem 0 0;font-size:.9rem}.breadcrumb-item+.breadcrumb-item:before{color:#6c757d}.breadcrumb-item a{color:var(--primary-color);text-decoration:none}.breadcrumb-item a:hover{color:var(--secondary-color)}.breadcrumb-item.active{color:#6c757d}@media(max-width:768px){.sidebar{left:calc(-1 * var(--sidebar-width))}.sidebar.mobile-open{left:0}.main-content{margin-left:0;padding:1rem}.sidebar-toggle{left:-20px}.sidebar-toggle.mobile-open{left:calc(var(--sidebar-width) - 20px)}.header{padding:0 .75rem}.header-brand{font-size:1rem;gap:.5rem}.header-brand .brand-logo{width:80px;height:35px;padding:.25rem;border-radius:6px;flex-shrink:0}.header-brand span{font-size:.9rem}.header-user-section{gap:.5rem}.logout-btn{padding:.4rem .75rem;font-size:.8rem;white-space:nowrap}.logout-btn i{font-size:.9rem}.user-name{display:none}.user-avatar{width:35px;height:35px;border:2px solid var(--secondary-color)}}@media(max-width:480px){.header{padding:0 .5rem}.header-brand{font-size:.85rem;gap:.4rem}.header-brand .brand-logo{width:60px;height:30px;padding:.2rem;flex-shrink:0}.header-brand span{font-size:.8rem;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-user-section{gap:.4rem}.logout-btn{padding:.35rem .5rem;font-size:.75rem}.logout-btn i{font-size:.85rem;margin-right:0}.user-avatar{width:30px;height:30px}}@media(max-width:360px){.header{padding:0 .4rem}.header-brand span{display:none}.header-brand .brand-logo{width:50px;height:28px;flex-shrink:0}.logout-btn{padding:.4rem;min-width:32px;display:flex;align-items:center;justify-content:center}.logout-btn .logout-text{display:none}.logout-btn i{margin:0}.user-avatar{width:28px;height:28px}}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff1a}.sidebar::-webkit-scrollbar-thumb{background:var(--secondary-color);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--secondary-color)}.voucher-table-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #00000014}.table-responsive{border-radius:8px}.voucher-table{margin-bottom:0}.voucher-table thead{background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff}.voucher-table thead th{font-weight:600;padding:1rem;border:none;white-space:nowrap}.voucher-table tbody tr{transition:all .2s ease}.voucher-table tbody tr:hover{background-color:#8b00000d}.voucher-table tbody td{padding:.875rem 1rem;vertical-align:middle}.status-badge{padding:.375rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;display:inline-block}.status-completed{background-color:#d4edda;color:#155724}.status-pending{background-color:#fff3cd;color:#856404}.status-progress{background-color:#d1ecf1;color:#0c5460}.status-cancelled{background-color:#f8d7da;color:#721c24}.preview-btn{background-color:var(--secondary-color);color:var(--primary-color);border:none;padding:.375rem .875rem;border-radius:5px;font-size:.85rem;font-weight:600;transition:all .2s ease;cursor:pointer}.preview-btn:hover{background-color:var(--secondary-color);transform:translateY(-2px);box-shadow:0 3px 6px #d4af374d}.voucher-preview{width:8.5in;min-height:11in;margin:0 auto;padding:.75in;background:#fff;box-shadow:0 0 10px #0000001a;position:relative}.voucher-header{text-align:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:3px solid var(--primary-color)}.voucher-header h2{color:var(--primary-color);font-weight:700;margin-bottom:.5rem;font-size:1.75rem}.voucher-header .voucher-number{color:var(--secondary-color);font-weight:600;font-size:1.1rem}.voucher-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.voucher-info-item{display:flex;padding:.5rem 0;border-bottom:1px solid #e9ecef}.voucher-info-label{font-weight:600;color:var(--primary-color);width:120px;flex-shrink:0}.voucher-info-value{color:#333;flex:1}.voucher-details-section{margin:1.5rem 0}.voucher-details-section h4{color:var(--primary-color);font-size:1.1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--secondary-color)}.amount-section{background:#f8f9fa;padding:1rem;border-radius:6px;margin:1rem 0;border-left:4px solid var(--secondary-color)}.amount-section .amount-label{font-weight:600;color:var(--primary-color);font-size:.95rem}.amount-section .amount-value{font-size:1.5rem;font-weight:700;color:var(--primary-color);margin-top:.25rem}.voucher-footer{margin-top:3rem;padding-top:2rem;border-top:2px solid #dee2e6}.signature-section{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:1.5rem}.signature-block{text-align:center}.signature-line{border-top:2px solid #333;margin-top:3rem;padding-top:.5rem;font-weight:600;color:#333}.signature-title{font-size:.85rem;color:#6c757d;margin-top:.25rem}.print-btn{background-color:var(--primary-color);color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;font-weight:600;transition:all .3s ease}.print-btn:hover{background-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 8px #8b00004d}@media print{body *{visibility:hidden}.voucher-preview,.voucher-preview *{visibility:visible}.voucher-preview{position:absolute;left:0;top:0;width:100%;box-shadow:none}@page{size:letter;margin:0}}.timeline-item{display:flex;gap:1.5rem;margin-bottom:2rem;position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:11px;top:30px;bottom:-20px;width:2px;background:#dee2e6}.timeline-marker{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);border:3px solid white;box-shadow:0 0 0 2px var(--primary-color);flex-shrink:0;margin-top:3px}.timeline-content{flex:1;background:#f8f9fa;padding:1.25rem;border-radius:10px;border-left:4px solid var(--secondary-color)}.timeline-header{display:flex;justify-content:space-between;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.timeline-date,.timeline-user{font-size:.85rem;color:#6c757d;font-weight:600;display:flex;align-items:center;gap:.4rem}.timeline-date i,.timeline-user i{color:var(--secondary-color)}.timeline-text{color:#212529;line-height:1.6;font-size:.95rem}#components-reconnect-modal,#components-offline-modal{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(4px);z-index:99999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}#components-offline-modal.show,#components-reconnect-modal.components-reconnect-show,#components-reconnect-modal.components-reconnect-failed,#components-reconnect-modal.components-reconnect-rejected,#components-reconnect-modal.show{opacity:1;visibility:visible}.reconnection-modal{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0000004d;max-width:500px;width:90%;padding:2.5rem 0;text-align:center;transform:scale(.9);transition:transform .3s ease;position:relative;min-height:400px;display:flex;align-items:center;justify-content:center}#components-reconnect-modal.components-reconnect-show .reconnection-modal,#components-reconnect-modal.components-reconnect-failed .reconnection-modal,#components-reconnect-modal.components-reconnect-rejected .reconnection-modal,#components-reconnect-modal.show .reconnection-modal,#components-offline-modal.show .reconnection-modal{transform:scale(1)}.reconnection-state{visibility:hidden;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;padding:0 2rem}#components-reconnect-modal.components-reconnect-show #reconnecting-state,#components-reconnect-modal.components-reconnect-failed #reconnection-failed-state,#components-reconnect-modal.components-reconnect-rejected #reconnection-rejected-state{visibility:visible}.offline-panel{visibility:hidden;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;padding:0 2rem}.reconnection-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;position:relative}.reconnection-icon i{font-size:2.5rem;z-index:2}.reconnection-icon-warning{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);box-shadow:0 4px 15px #d4af374d}.reconnection-icon-warning i{color:var(--primary-color)}.reconnection-icon-error{background:linear-gradient(135deg,#dc3545,#c82333);box-shadow:0 4px 15px #dc35454d}.reconnection-icon-error i{color:#fff}.pulse-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;border:3px solid var(--secondary-color);border-radius:50%;animation:pulse-ring 1.5s ease-out infinite}@keyframes pulse-ring{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(1.4);opacity:0}}.reconnection-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:.75rem}.reconnection-title-warning{color:var(--primary-color)}.reconnection-title-error{color:#dc3545}.spin-icon{animation:spin 1s linear infinite;font-size:1.3rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reconnection-message{color:#6c757d;font-size:.95rem;line-height:1.6;margin-bottom:1.5rem}.reconnection-attempt-info{margin-bottom:1.5rem}.attempt-badge{display:inline-block;background:linear-gradient(to bottom,#f8f9fa,#e9ecef);color:var(--primary-color);padding:.5rem 1.25rem;border-radius:20px;font-size:.9rem;font-weight:600;border:2px solid var(--secondary-color)}.attempt-badge span{color:var(--secondary-color);font-weight:700}.reconnection-progress{width:100%;height:8px;background:#e9ecef;border-radius:10px;overflow:hidden;margin-bottom:1rem}.progress-bar-animated{height:100%;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);border-radius:10px;animation:progress-indeterminate 1.5s ease-in-out infinite;width:40%}@keyframes progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(350%)}}.reconnection-btn{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);color:var(--primary-color);border:none;border-radius:10px;padding:.9rem 2rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #d4af374d;display:inline-flex;align-items:center;gap:.75rem;margin-top:.5rem}.reconnection-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%)}.reconnection-btn:active{transform:translateY(0)}.reconnection-btn i{font-size:1.2rem}.reconnection-btn-error{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;box-shadow:0 4px 15px #dc35454d}.reconnection-btn-error:hover{box-shadow:0 6px 20px #dc354566;background:linear-gradient(135deg,#c82333,#bd2130)}.reconnection-btn-warning{background:linear-gradient(135deg,#ffc107,#e0a800);color:#333;box-shadow:0 4px 15px #ffc1074d}.reconnection-btn-warning:hover{box-shadow:0 6px 20px #ffc10766;background:linear-gradient(135deg,#e0a800,#d39e00)}.reconnection-icon-offline{background:linear-gradient(135deg,#6c757d,#5a6268);box-shadow:0 4px 15px #6c757d4d}.reconnection-icon-offline i{color:#fff}.reconnection-title-offline{color:#6c757d}.reconnection-btn-offline{background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff;box-shadow:0 4px 15px #6c757d4d}.reconnection-btn-offline:hover{box-shadow:0 6px 20px #6c757d66;background:linear-gradient(135deg,#5a6268,#4e555b)}.reconnection-btn-offline-secondary{background:transparent;color:#6c757d;border:2px solid #6c757d;box-shadow:none}.reconnection-btn-offline-secondary:hover{background:#f8f9fa;border-color:#5a6268;color:#5a6268;box-shadow:none}.action-buttons-container{display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem;border-top:2px solid #f1f3f5;flex-wrap:wrap}.add-new-btn{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);color:var(--primary-color);border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .3s ease;cursor:pointer;box-shadow:0 4px 12px #d4af374d;display:flex;align-items:center;gap:.5rem}.add-new-btn:hover{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);transform:translateY(-2px);box-shadow:0 6px 16px #d4af3766}.add-new-btn i{font-size:1.1rem}.btn{padding:.65rem 1.5rem;font-weight:600;border-radius:8px;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);color:var(--primary-color);border:none}.btn-primary:hover{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);transform:translateY(-2px);box-shadow:0 4px 12px #d4af3766;color:var(--primary-color)}.btn-secondary{background-color:#6c757d;border:none}.btn-secondary:hover{background-color:#5c636a;transform:translateY(-2px)}.btn-warning{background:linear-gradient(135deg,#ffc107,#e0a800);color:#495057;border:none}.btn-warning:hover{background:linear-gradient(135deg,#e0a800,#ffc107);transform:translateY(-2px);box-shadow:0 4px 12px #ffc10766;color:#495057}.filter-section{margin-bottom:1.5rem}.filter-label{font-size:.85rem;font-weight:600;color:#6c757d;margin-bottom:.25rem;display:block}.search-box{position:relative;width:100%}.search-box input{width:100%;padding:.65rem 1rem .65rem 2.75rem;border:2px solid #e9ecef;border-radius:8px;font-size:.95rem;transition:all .3s ease}.search-box input:focus{outline:none;border-color:var(--secondary-color);box-shadow:0 0 0 .2rem #d4af3726}.search-box i{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#6c757d;font-size:1.1rem}.form-select-custom,.form-control-custom{border:2px solid #e9ecef;border-radius:8px;padding:.65rem 1rem;font-size:.95rem;transition:all .3s ease}.form-select-custom:focus,.form-control-custom:focus{border-color:var(--secondary-color);box-shadow:0 0 0 .2rem #d4af3726}.modal-header{background:#f8f9fa;border-bottom:2px solid #e9ecef}.modal-title{color:var(--primary-color);font-weight:700;display:flex;align-items:center;gap:.75rem}.modal-title i{color:var(--secondary-color);font-size:1.3rem}.filter-modal-label{font-weight:600;color:#495057;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.filter-modal-label i{color:var(--secondary-color)}.form-control-custom,.form-select-custom{border:2px solid #e9ecef;border-radius:6px;padding:.6rem 1rem;font-size:.95rem;transition:all .3s ease}.form-control-custom:focus,.form-select-custom:focus{outline:none;border-color:var(--secondary-color);box-shadow:0 0 0 .2rem #d4af3726;background-color:#fffbf0}.btn-primary-filter{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);color:var(--primary-color);border:none;padding:.6rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-primary-filter:hover{background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-color) 100%);box-shadow:0 4px 8px #d4af374d;transform:translateY(-1px)}@media(max-width:768px){.reconnection-modal{padding:2rem 0;max-width:95%;min-height:350px}.reconnection-state,.offline-panel{padding:0 1.5rem}.reconnection-icon{width:70px;height:70px}.reconnection-icon i{font-size:2rem}.reconnection-title{font-size:1.3rem}.reconnection-message{font-size:.9rem}.reconnection-btn{padding:.75rem 1.5rem;font-size:.95rem}}
