body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.login-container{align-items:center;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;width:100%}.login-box .logo{color:#667eea;font-size:48px;font-weight:700;margin-bottom:10px;text-align:center}.login-box h2{color:#333;margin-bottom:30px;text-align:center}.login-box form input{border:2px solid #e2e8f0;border-radius:8px;font-size:16px;margin-bottom:15px;padding:12px;transition:border .3s;width:100%}.login-box form input:focus{border-color:#667eea;outline:none}.login-box form button{background:#1e3a8a 0;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:12px;transition:transform .2s;width:100%}.login-box form button:hover{transform:translateY(-2px)}.login-help{border-top:1px solid #e2e8f0;color:#666;font-size:14px;margin-top:20px;padding-top:20px;text-align:center}.login-help code{background:#f7fafc;border-radius:4px;color:#667eea;font-weight:700;padding:2px 6px}.app{background:#f5f7fa;min-height:100vh}.header{background:linear-gradient(135deg,#1e3a8a,#3b82f6);box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;flex-direction:column;gap:15px;padding:15px 30px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.logo{flex-shrink:0;font-size:32px;font-weight:700;letter-spacing:-1px}.header-top{align-items:center;display:flex;justify-content:space-between}.header-bottom{flex-wrap:wrap}.header-bottom,.header-center,.header-user{align-items:center;display:flex;gap:15px}.header-center{flex:1 1;flex-wrap:wrap;justify-content:center}.year-selector{background:#ffffff1a;border-radius:8px;display:flex;gap:5px;padding:5px}.year-selector button{background:#0000;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 20px;transition:background .3s}.year-selector button.active{background:#4ade80;color:#1e293b}.month-selector{display:flex;flex-wrap:wrap;gap:5px}.month-selector button{background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s}.month-selector button.active{background:#4ade80;color:#1e293b;transform:scale(1.05)}.header-right{flex-shrink:0;flex-wrap:nowrap;gap:15px}.header-actions,.header-right{align-items:center;display:flex}.header-actions{flex-wrap:wrap;gap:10px}.icon-btn{background:#ffffff1a;border:none;border-radius:8%;color:#fff;cursor:pointer;font-weight:600;padding:10px 16px;position:relative;transition:all .3s}.icon-btn:hover{background:#fff3;transform:translateY(-2px)}.badge{background:#ef4444;border-radius:50%;display:flex;position:absolute;right:-5px;top:-5px;width:20px}.user-info{align-items:center;background:#ffffff1a;border-radius:8px;display:flex;gap:10px;padding:8px 15px}.btn-logout{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:6px 12px;transition:background .3s}.btn-logout:hover{background:#dc2626}.legend{background:#fff;border-bottom:2px solid #e2e8f0;flex-wrap:wrap;gap:10px;padding:10px;position:-webkit-sticky;position:sticky;top:150px;z-index:90}.legend,.legend-item{align-items:center;display:flex}.legend-item{font-size:14px;font-weight:500;gap:8px}.search-container{display:flex;margin-left:auto}.search-input{border:2px solid #e2e8f0;border-radius:20px;font-size:14px;padding:8px 16px;transition:all .2s;width:250px}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 12px;transition:all .2s}.filter-select:hover{border-color:#667eea}.filter-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.btn-clear-filters{align-items:center;background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:8px 12px;transition:all .2s}.btn-clear-filters:hover{background:#dc2626;transform:scale(1.1)}.filter-count{background:#eff6ff;border:2px solid #3b82f6;border-radius:8px;color:#1e40af;font-size:13px;font-weight:700;padding:8px 12px}.main-content{padding:20px}.table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000d;overflow:visible}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:#f8fafc;position:-webkit-sticky;position:sticky;top:230px;z-index:80}.data-table th{border-bottom:2px solid #e2e8f0;color:#475569;font-size:11px;font-weight:700;padding:15px 10px;text-align:left;text-transform:uppercase}.col-client{min-width:180px;width:200px}.col-proceso{cursor:help;font-size:11.5px;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;max-height:3.9em;max-width:130px;min-width:100px;overflow:hidden;padding:14px 10px;text-align:center;transition:background-color .2s ease;white-space:normal;word-break:break-word}.col-proceso:hover{background-color:#3b82f60d}.data-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .2s}.data-table tbody tr:hover{background:#f8fafc}.section-header{background:#e0e7ff!important;color:#4338ca;font-weight:700}.section-header td{font-size:13px;letter-spacing:.5px;padding:12px 15px}.client-name{color:#1e293b;font-weight:600;padding:15px}.client-employee{color:#64748b;font-size:12px;font-weight:400;margin-top:4px}.client-billing-frequency{background:#d1fae5;border-radius:4px;color:#059669;display:inline-block;font-size:11px;font-weight:500;margin-top:4px;padding:2px 8px}.cell-estado{padding:10px}.estado-circle{align-items:center;border:none;border-radius:50%;box-shadow:0 2px 5px #0003;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:35px;justify-content:center;transition:all .3s;width:35px}.estado-circle.verde{animation:pulse-azul-verde 2s infinite;background:#22c55e;box-shadow:0 0 0 3px #3b82f633;color:#fff}.estado-circle.amarillo{background:#fbbf24}.estado-circle.rojo{background:#ef4444}.estado-circle.azul{background:#22c55e;border:2px solid #003ea1;color:#003ea1}.estado-circle:hover{box-shadow:0 4px 12px #0006;transform:scale(1.15)}.estado-badge{display:inline-block;font-size:12px}.estado-badge.verde{background:#dcfce7;color:#166534}.empty-state{color:#64748b}.empty-state button{background:#0052ff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:20px;padding:12px 24px;transition:background .3s}.empty-state button:hover{background:#0041cc}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{max-height:80vh;padding:0}.modal,.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-width:600px;overflow:hidden;width:90%}.modal-content{max-height:85vh;padding:20px}.modal-body{flex:1 1;overflow-y:auto;padding:20px 0}.modal-messages{max-width:700px}.modal-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 25px}.modal-header h3{color:#1e293b;font-size:20px;margin:0}.modal-header button{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-header button:hover{background:#e2e8f0;color:#1e293b}.historial-list{max-height:500px;overflow-y:auto;padding:20px}.historial-item{border:1px solid #e2e8f0;border-radius:8px;margin-bottom:12px;padding:15px;transition:all .2s}.historial-item:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.hist-main{font-size:14px;margin-bottom:8px}.hist-change{align-items:center;display:flex;gap:10px;margin-bottom:8px}.hist-meta{color:#64748b;font-size:12px}.modal-messages-chat{display:flex;flex-direction:column;height:600px;max-height:90vh;max-width:1000px;width:90%}.chat-container{display:flex;height:calc(100% - 60px);overflow:hidden}.conversations-list{background:#f8fafc;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;width:320px}.conversations-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:15px 20px}.conversations-header h4{color:#1e293b;font-size:16px;margin:0}.conversation-item{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;cursor:pointer;display:flex;padding:12px 20px;transition:background .2s}.conversation-item:hover{background:#f1f5f9}.conversation-item.active{background:#e0f2fe;border-left:3px solid #0052ff}.conversation-item.has-unread{background:#eff6ff}.conv-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:45px;justify-content:center;margin-right:12px;width:45px}.conv-info{flex:1 1;min-width:0}.conv-name{color:#1e293b;font-size:14px;font-weight:600;margin-bottom:4px}.conv-last-message{color:#64748b;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-meta{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.conv-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:11px;font-weight:700;min-width:20px;padding:2px 7px;text-align:center}.conv-time{color:#94a3b8;font-size:11px}.empty-conversations{color:#64748b;padding:40px 20px;text-align:center}.empty-conversations p{font-weight:600;margin:0 0 8px}.empty-conversations small{font-size:12px}.users-available{border-top:2px solid #e2e8f0;flex:1 1;overflow-y:auto;padding:15px 20px}.users-available h5{color:#64748b;font-size:13px;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.user-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;margin-bottom:5px;padding:10px;transition:background .2s}.user-item:hover{background:#e2e8f0}.user-avatar{align-items:center;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:50%;color:#fff;display:flex;font-weight:600;height:35px;justify-content:center;margin-right:10px;width:35px}.user-avatar,.user-name{font-size:14px}.chat-area{flex:1 1;flex-direction:column}.chat-area,.chat-header{background:#fff;display:flex}.chat-header{align-items:center;border-bottom:1px solid #e2e8f0;gap:15px;padding:15px 20px}.btn-back{background:#f1f5f9;border:none;border-radius:50%;color:#475569;cursor:pointer;display:none;font-size:18px;height:35px;transition:background .2s;width:35px}.btn-back:hover{background:#e2e8f0}.chat-user-info{gap:12px}.chat-avatar,.chat-user-info{align-items:center;display:flex}.chat-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.chat-user-name{color:#1e293b;font-size:15px;font-weight:600}.chat-messages{background:#f8fafc;display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:20px}.chat-message{align-items:flex-end;animation:messageSlideIn .3s ease;display:flex;gap:8px;max-width:70%}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.message-sent{align-self:flex-end;flex-direction:row-reverse}.chat-message.message-received{align-self:flex-start}.message-bubble{background:#fff;border-radius:12px;box-shadow:0 1px 2px #0000000d;padding:10px 14px;position:relative}.message-sent .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.message-text{word-wrap:break-word;font-size:14px;line-height:1.5;margin-bottom:4px}.message-sent .message-text{color:#fff}.message-time{color:#94a3b8;font-size:11px;text-align:right}.message-sent .message-time{color:#fffc}.btn-reply-mini{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#475569;cursor:pointer;display:none;flex-shrink:0;font-size:14px;height:28px;justify-content:center;transition:all .2s;width:28px}.chat-message:hover .btn-reply-mini{display:flex}.btn-reply-mini:hover{background:#10b981;color:#fff;transform:scale(1.1)}.chat-message .mensaje-padre{background:#0000000d;border-left:3px solid #64748b;border-radius:6px;font-size:12px;margin-bottom:8px;padding:6px 10px}.message-sent .mensaje-padre{background:#fff3;border-left-color:#ffffff80}.mensaje-padre small{display:block;font-weight:600;margin-bottom:3px;opacity:.8}.mensaje-padre p{font-style:italic;margin:0;opacity:.9}.empty-chat{align-items:center;color:#64748b;display:flex;flex-direction:column;height:100%;justify-content:center}.empty-chat p{font-size:15px;font-weight:600;margin:0 0 5px}.empty-chat small{font-size:13px}.no-chat-selected{align-items:center;color:#64748b;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px;text-align:center}.no-chat-icon{font-size:64px;margin-bottom:20px;opacity:.3}.no-chat-selected h4{color:#1e293b;margin:0 0 10px}.no-chat-selected p{font-size:14px;margin:0}.admin-notes-container{display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:30px}.admin-notes-header{margin-bottom:20px;text-align:center}.admin-notes-icon{font-size:48px;margin-bottom:15px}.admin-notes-header h4{color:#1e293b;font-size:20px;margin:0 0 10px}.admin-notes-header p{color:#64748b;font-size:14px;margin:0}.admin-notes-textarea{border:2px solid #e2e8f0;border-radius:8px;flex:1 1;font-family:inherit;font-size:14px;margin-bottom:15px;min-height:300px;padding:15px;resize:vertical;transition:border-color .2s;width:100%}.admin-notes-textarea:focus{border-color:#667eea;outline:none}.btn-guardar-notas{align-self:flex-end;background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-guardar-notas:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.btn-guardar-notas:disabled{cursor:not-allowed;opacity:.6}.admin-notes-readonly{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;flex:1 1;overflow-y:auto;padding:20px;width:100%}.notes-content{word-wrap:break-word;color:#1e293b;font-size:14px;line-height:1.6;white-space:pre-wrap}.notes-empty{color:#94a3b8;font-style:italic;padding:40px 20px;text-align:center}.reply-indicator-chat{align-items:center;background:#fff7ed;border-top:2px solid #fb923c;display:flex;justify-content:space-between;padding:10px 20px}.reply-indicator-chat .reply-info{flex:1 1}.reply-indicator-chat small{color:#ea580c;display:block;font-size:11px;font-weight:600;margin-bottom:3px}.reply-indicator-chat p{color:#7c2d12;font-size:12px;font-style:italic;margin:0}.reply-indicator-chat .btn-cancel-reply{align-items:center;background:#fed7aa;border:none;border-radius:50%;color:#ea580c;cursor:pointer;display:flex;font-size:14px;height:28px;justify-content:center;transition:all .2s;width:28px}.reply-indicator-chat .btn-cancel-reply:hover{background:#fb923c;color:#fff;transform:rotate(90deg)}.chat-input-form{align-items:center;background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:10px;padding:15px 20px}.chat-input-form textarea{border:2px solid #e2e8f0;border-radius:20px;flex:1 1;font-family:inherit;font-size:14px;max-height:100px;min-height:40px;outline:none;padding:10px 15px;resize:none;transition:border-color .2s}.chat-input-form textarea:focus{border-color:#0052ff}.chat-input-form button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;transition:transform .2s;width:40px}.chat-input-form button:hover{transform:scale(1.1)}.chat-input-form button:active{transform:scale(.95)}.chat-messages::-webkit-scrollbar,.users-available::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track,.users-available::-webkit-scrollbar-track{background:#0000}.chat-messages::-webkit-scrollbar-thumb,.users-available::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.chat-messages::-webkit-scrollbar-thumb:hover,.users-available::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:768px){.modal-messages-chat{height:90vh;width:95%}.chat-container{position:relative}.conversations-list{width:100%}.chat-area{height:100%;left:0;position:absolute;top:0;transform:translateX(100%);transition:transform .3s ease;width:100%}.chat-area.active{transform:translateX(0)}.btn-back{display:flex}.chat-message{max-width:85%}.users-available{max-height:200px}}@media (max-width:480px){.chat-message{max-width:90%}.conv-avatar{font-size:16px;height:40px;width:40px}.conversation-item{padding:10px 15px}}.loading-chat{align-items:center;color:#64748b;display:flex;flex-direction:column;height:100%;justify-content:center}.spinner{animation:spin .8s linear infinite;border:4px solid #e2e8f0;height:40px;margin-bottom:15px;width:40px}.loading-chat p{font-size:14px;margin:0}.input-wrapper{flex:1 1;position:relative}.input-wrapper textarea{width:100%}.client-form{display:flex;flex-direction:column;gap:15px;max-height:calc(90vh - 80px);overflow-y:auto;padding:20px}.client-form input,.client-form select{border:2px solid #e2e8f0;border-radius:15px;font-family:inherit;font-size:14px;padding:12px;width:100%}.client-form button{background:#0052ff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px;transition:background .3s;width:100%}.client-form button:hover{background:#0041cc}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.btn-files{background:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 12px;transition:all .3s}.btn-files:hover{background:#1976d2;transform:translateY(-2px)}.modal-files{max-width:700px}.modal-settings{max-height:85vh;max-width:800px}.settings-tabs{background:#f8fafc;border-bottom:2px solid #e2e8f0;display:flex;padding:0}.settings-tabs button{background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;flex:1 1;font-weight:600;padding:15px 20px;transition:all .3s}.settings-tabs button:hover{background:#f1f5f9;color:#334155}.settings-tabs button.active{background:#fff;border-bottom-color:#0052ff;color:#0052ff}.settings-content{max-height:calc(85vh - 140px);overflow-y:auto;padding:25px}.settings-form{max-width:500px}.settings-form h4{color:#1e293b;font-size:18px}.form-group,.settings-form h4{margin-bottom:20px}.form-group label{color:#475569;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:12px;transition:border .3s;width:100%}.form-group input:focus{border-color:#0052ff;outline:none}.form-group small{color:#64748b;display:block;font-size:12px;margin-top:5px}.btn-primary{background:#0052ff;font-size:14px;padding:12px 24px;transition:all .3s}.btn-primary:hover{background:#0041cc;transform:translateY(-2px)}.users-management{display:flex;flex-direction:column;gap:30px}.users-section h4{align-items:center;color:#1e293b;display:flex;font-size:16px;gap:8px;margin-bottom:15px}.user-form{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:20px}.user-form input,.user-form select{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:12px}.user-form input:focus,.user-form select:focus{border-color:#0052ff;outline:none}.btn-success{background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px;transition:all .3s}.btn-success:hover{background:#059669;transform:translateY(-2px)}.users-list{display:flex;flex-direction:column;gap:12px}.user-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;justify-content:space-between;padding:15px 20px;transition:all .2s}.user-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.user-card.inactive{background:#f8fafc;opacity:.6}.user-info-card{flex:1 1}.user-name{align-items:center;color:#1e293b;display:flex;font-weight:600;gap:8px;margin-bottom:4px}.user-meta{color:#64748b;font-size:13px}.badge-you{background:#dbeafe;color:#1e40af}.badge-inactive,.badge-you{border-radius:4px;font-size:11px;font-weight:700;padding:2px 8px}.badge-inactive{background:#fee2e2;color:#991b1b}.user-actions{display:flex;gap:8px}.btn-icon{align-items:center;background:#f1f5f9;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:all .2s;width:36px}.btn-icon:hover{background:#e2e8f0;transform:scale(1.1)}.btn-icon.btn-danger:hover{background:#fee2e2}.edit-user-form{display:flex;flex-direction:column;gap:10px;width:100%}.edit-user-form input{border:2px solid #e2e8f0;border-radius:6px;font-size:13px;padding:10px}.edit-actions{display:flex;gap:8px}.btn-small{background:#e2e8f0;border:none;border-radius:6px;color:#334155;cursor:pointer;font-size:13px;font-weight:600;padding:8px 12px;transition:all .2s}.btn-small:hover{background:#cbd5e1}.btn-small.btn-success{background:#10b981;color:#fff}.btn-small.btn-success:hover{background:#059669}.files-upload-section{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;gap:15px;padding:20px}.upload-btn{background:#10b981;border-radius:8px;color:#fff;cursor:pointer;display:inline-block;font-weight:600;padding:12px 24px;transition:all .3s}.upload-btn:hover{background:#059669;transform:translateY(-2px)}.upload-hint{color:#64748b;font-size:12px}.files-list{max-height:450px;overflow-y:auto;padding:20px}.empty-files{color:#94a3b8;font-style:italic;padding:40px;text-align:center}.file-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:15px;margin-bottom:10px;padding:15px;transition:all .2s}.file-item:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.file-icon{flex-shrink:0;font-size:32px}.file-info{flex:1 1;min-width:0}.file-name{color:#1e293b;font-weight:600;margin-bottom:4px;word-break:break-word}.file-meta{color:#64748b;font-size:12px}.file-actions{display:flex;flex-shrink:0;gap:8px}.btn-delete,.btn-download{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:18px;height:36px;justify-content:center;transition:all .2s;width:36px}.btn-download{background:#dbeafe}.btn-download:hover{background:#bfdbfe;transform:scale(1.1)}.btn-delete{background:#fee2e2}.btn-delete:hover{background:#fecaca;transform:scale(1.1)}@media (max-width:1200px){.header{align-items:flex-start;flex-direction:column}.header-center,.header-right{width:100%}}@media (max-width:768px){.month-selector button{font-size:10px;padding:4px 8px}.data-table th{font-size:9px;padding:10px 5px}.estado-circle{font-size:16px;height:35px;width:35px}.legend{flex-wrap:wrap;gap:15px}.file-item{align-items:flex-start;flex-direction:column}.file-actions{justify-content:flex-end;width:100%}}.search-container{margin:15px auto;max-width:600px;padding:0 20px;text-align:center}.search-input{font-Size:16px;border:2px solid #ddd;border-radius:25px;box-shadow:0 2px 5px #0000001a;outline:none;padding:12px 20px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#4caf50;box-shadow:0 2px 10px #4caf504d}.search-results{color:#666;display:block;font-size:14px;margin-top:8px}.modal-notificaciones{max-height:90vh;max-width:1200px;overflow-y:auto;width:95%}.notifications-tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:0;margin-bottom:20px}.notifications-tabs button{background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;flex:1 1;font-weight:600;padding:15px 20px;transition:all .3s}.notifications-tabs button:hover{background:#f8fafc;color:#334155}.notifications-tabs button.active{background:#f8fafc;border-bottom-color:#667eea;color:#667eea}.notifications-content{padding:20px}.section-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:20px;padding:25px}.section-card h4{color:#1e293b;font-size:18px;margin-bottom:8px;margin-top:0}.section-card>p{color:#64748b;margin-bottom:20px}.massive-send-buttons{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.btn-massive{border:2px solid;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;font-size:16px;font-weight:600;gap:8px;padding:20px;text-align:left;transition:all .3s}.btn-massive small{font-size:13px;font-weight:400;opacity:.8}.btn-massive.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.btn-massive.btn-primary:hover{box-shadow:0 8px 16px #667eea4d;transform:translateY(-2px)}.btn-massive.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b;color:#fff}.btn-massive.btn-warning:hover{box-shadow:0 8px 16px #f59e0b4d;transform:translateY(-2px)}.select-tipo-notificacion{background:#fff;cursor:pointer}.select-tipo-notificacion,.textarea-mensaje{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:12px;width:100%}.textarea-mensaje{font-family:inherit;resize:vertical}.clientes-seleccion{margin-top:20px}.seleccion-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.seleccion-header h5{color:#1e293b;margin:0}.btn-select-all{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.btn-select-all:hover{background:#e2e8f0;border-color:#94a3b8}.clientes-list-select{border:2px solid #e2e8f0;border-radius:8px;max-height:400px;overflow-y:auto;padding:10px}.cliente-select-item{align-items:flex-start;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s}.cliente-select-item:hover:not(.sin-contacto){background:#f8fafc;border-color:#e2e8f0}.cliente-select-item.selected{background:#eff6ff;border-color:#3b82f6}.cliente-select-item.sin-contacto{background:#fafafa;cursor:not-allowed;opacity:.5}.cliente-select-item input[type=checkbox]{cursor:pointer;height:18px;margin-top:2px;width:18px}.cliente-select-info{flex:1 1}.cliente-select-info strong{color:#1e293b;display:block;margin-bottom:4px}.cliente-contactos{color:#64748b;display:flex;flex-wrap:wrap;font-size:12px;gap:10px}.sin-contacto-text{color:#ef4444!important;font-weight:600}.btn-enviar-notificaciones{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:20px;padding:15px;transition:all .3s;width:100%}.btn-enviar-notificaciones:hover:not(:disabled){box-shadow:0 8px 16px #10b9814d;transform:translateY(-2px)}.btn-enviar-notificaciones:disabled{background:#cbd5e1;cursor:not-allowed;opacity:.6}.contactos-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:25px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;padding:20px;text-align:center}.stat-number{font-size:32px;font-weight:700;margin-bottom:5px}.stat-label{font-size:14px;opacity:.9}.contactos-list{display:flex;flex-direction:column;gap:10px}.contacto-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;padding:15px;transition:all .2s}.contacto-item:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d}.contacto-nombre{align-items:center;display:flex;gap:10px}.tipo-badge{background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;font-size:12px;font-weight:600;padding:4px 10px}.btn-editar-contacto{background:#fff;border:2px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s}.btn-editar-contacto:hover{background:#667eea;color:#fff}.programadas-list{display:flex;flex-direction:column;gap:15px}.programada-card{align-items:flex-start;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;display:flex;gap:20px;padding:20px}.programada-icon{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;font-size:32px;height:60px;justify-content:center;width:60px}.programada-info{flex:1 1}.programada-info h5{color:#1e293b;margin:0 0 8px}.programada-info>p{color:#64748b;font-size:14px;margin:0 0 12px}.programada-detalles{color:#64748b;display:flex;flex-wrap:wrap;font-size:13px;gap:12px}.programada-status{align-self:flex-start;border-radius:20px;font-size:13px;font-weight:600;padding:8px 16px}.programada-status.activa{background:#d1fae5;color:#065f46}.programada-status.inactiva{background:#fee2e2;color:#991b1b}.reporte-actions{display:flex;gap:10px;margin-bottom:16px}.reporte-email-item{align-items:flex-start;border:1px solid #e2e8f0;border-left:5px solid #94a3b8;border-radius:8px;display:flex;gap:12px;justify-content:space-between;margin-bottom:10px;padding:12px}.reporte-email-item.enviado{border-left-color:#10b981}.reporte-email-item.fallido{border-left-color:#ef4444}.info-box{background:#eff6ff;border:2px solid #bfdbfe;border-radius:10px;margin-top:20px;padding:20px}.info-box h5{color:#1e40af;margin-top:0}.info-box ul{margin:0;padding-left:20px}.info-box li{color:#1e3a8a;line-height:1.6;margin-bottom:8px}@media (max-width:768px){.modal-notificaciones{border-radius:0;height:100vh;max-height:100vh;width:100%}.notifications-tabs button{font-size:13px;padding:12px 10px}.contactos-stats,.massive-send-buttons{grid-template-columns:1fr}.programada-card{flex-direction:column}}.modal-procesos-detalle{display:flex;flex-direction:column;max-height:85vh;max-width:900px;width:90%}.procesos-tabs{background:#f8fafc;border-bottom:2px solid #e2e8f0;overflow-x:auto;white-space:nowrap}.procesos-tabs,.procesos-tabs button{display:flex;gap:8px;padding:10px 20px}.procesos-tabs button{align-items:center;background:#fff;border:none;border-radius:8px 8px 0 0;cursor:pointer;flex-shrink:0;font-weight:500;transition:all .3s}.procesos-tabs button:hover{background:#e0e7ff;transform:translateY(-2px)}.procesos-tabs button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea66;color:#fff}.tab-count{border-radius:12px;font-size:12px;padding:2px 8px}.procesos-tabs button.active .tab-count,.tab-count{background:#ffffff4d}.procesos-content{flex:1 1;overflow-y:auto;padding:20px}.proceso-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px 20px;transition:all .3s}.proceso-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateX(5px)}.proceso-info h4{color:#1e293b;font-size:16px;margin:0 0 5px}.proceso-meta{color:#64748b;display:flex;font-size:12px;gap:15px}.estado-container{align-items:center;display:flex;flex-direction:column;gap:5px}.estado-circle-large{border:none;border-radius:50%;cursor:pointer;font-size:24px;height:50px;transition:all .3s;width:50px}.estado-circle-large:hover{transform:scale(1.1)}.estado-circle-large.verde{animation:pulse-azul-verde 2s infinite;background:#10b981;box-shadow:0 0 0 3px #3b82f633;color:#fff}.estado-circle-large.amarillo{background:#f59e0b;color:#fff}.estado-circle-large.rojo{background:#ef4444;color:#fff}.estado-circle-large.azul{background:#fff;border:3px solid #2563eb;color:#2563eb}.estado-fecha{color:#64748b;font-size:10px;text-align:center;white-space:nowrap}.comentarios-container{display:flex;flex-direction:column;gap:20px;height:100%}.comentario-form{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:20px}.comentario-form h4{align-items:center;color:#1e293b;display:flex;font-size:16px;gap:8px;margin:0 0 15px}.comentario-form h4:before{font-size:20px}.comentario-form textarea{border:1px solid #cbd5e1;border-radius:8px;font-family:inherit;font-size:14px;min-height:100px;padding:12px;resize:vertical;transition:border-color .3s;width:100%}.comentario-form textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.comentario-form textarea:disabled{background:#f1f5f9;cursor:not-allowed}.comentario-form-footer{align-items:center;display:flex;justify-content:space-between;margin-top:12px}.char-count{color:#64748b;font-size:12px}.btn-agregar-comentario{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s}.btn-agregar-comentario:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.btn-agregar-comentario:disabled{background:#cbd5e1;cursor:not-allowed;transform:none}.comentarios-lista{flex:1 1;overflow-y:auto}.comentarios-lista h4{align-items:center;color:#1e293b;display:flex;font-size:16px;gap:8px;margin:0 0 15px}.comentarios-lista h4:before{font-size:20px}.comentarios-vacio{color:#64748b;padding:40px 20px;text-align:center}.comentarios-vacio p:first-child{font-size:16px;font-weight:600;margin-bottom:8px}.comentarios-vacio p:last-child{font-size:14px}.comentario-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;padding:16px;transition:all .3s}.comentario-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.comentario-header{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.comentario-usuario{align-items:center;display:flex;gap:10px}.usuario-nombre{color:#1e293b;font-size:14px}.usuario-badge{border-radius:20px;font-size:12px;font-weight:600;padding:4px 12px}.usuario-badge.admin{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.usuario-badge.contador{background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff}.comentario-acciones{align-items:center;display:flex;gap:12px}.comentario-fecha{color:#64748b;font-size:12px}.btn-eliminar-comentario{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:18px;padding:4px 8px;transition:all .3s}.btn-eliminar-comentario:hover{background:#fee2e2;transform:scale(1.1)}.comentario-texto{color:#334155;font-size:14px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.procesos-resumen{grid-gap:15px;background:#f8fafc;border-top:2px solid #e2e8f0;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:20px}.resumen-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;padding:15px}.resumen-nombre{color:#1e293b;font-weight:600;margin-bottom:10px}.resumen-progreso{align-items:center;display:flex;gap:10px}.progreso-bar{background:#e2e8f0;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progreso-fill{background:linear-gradient(90deg,#10b981,#059669);height:100%;transition:width .5s ease}.resumen-progreso span{color:#64748b;font-size:14px;font-weight:600}.header-actions,.menu-container{display:inline-block;position:relative}.menu-btn{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff14;border:1px solid #ffffff1f;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;padding:10px 20px;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.menu-btn:hover{background:#ffffff1f;transform:translateY(-1px)}.menu-btn:active{transform:translateY(0)}.dropdown-menu{background:linear-gradient(180deg,#fffffffa,#f9f9fafa);border-radius:12px;box-shadow:0 12px 30px #080f1e2e;left:0;min-width:220px;opacity:0;overflow:hidden;padding:8px;pointer-events:none;position:absolute;top:calc(100% + 8px);transform:translateY(-8px) scale(.98);transform-origin:top left;transition:all .16s cubic-bezier(.2,.9,.2,1);z-index:1200}.dropdown-menu.user-dropdown{left:auto;right:0;transform-origin:top right}.menu-overlay{background:#0000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1100}.dropdown-menu.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}.dropdown-menu button{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:10px 12px;text-align:left;transition:background .12s ease;width:100%}.dropdown-menu .divider{background:#0000000f;height:1px;margin:6px 0}.dropdown-menu button:hover{background:#0f172a0a}.dropdown-header{border-bottom:1px solid #0000000f;margin-bottom:8px;padding:12px;text-align:center}.user-avatar-large{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:20px;font-weight:600;height:50px;justify-content:center;margin:0 auto;width:50px}.logout-option{color:#ef4444!important;font-weight:500}.logout-option:hover{background:#ef444414!important}.badge{align-items:center;background:linear-gradient(90deg,#ef4444,#f97316);border-radius:999px;color:#fff;display:inline-flex;font-size:11px;font-weight:700;height:20px;justify-content:center;line-height:1;margin-left:8px;min-width:20px;padding:0 6px;text-align:center}.dropdown-menu button.admin{font-weight:600}@media (max-width:768px){.dropdown-menu{max-width:calc(100vw - 32px);min-width:200px}.dropdown-menu.user-dropdown{right:0}}@media (max-width:480px){.dropdown-menu{left:auto;min-width:180px;right:0}.dropdown-menu button{font-size:13px;padding:10px}.user-avatar-large{font-size:16px;height:40px;width:40px}}.btn-ver-detalle{align-items:center;background:#c0bdbd;border:none;border-radius:6px;color:#000;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:4px;margin-left:10px;padding:6px 12px;position:relative;transition:all .3s}.btn-ver-detalle:hover{box-shadow:0 4px 8px #82848d4d;transform:translateY(-2px)}.client-actions-section{align-items:center;align-self:center;display:flex;flex-direction:column;gap:4px}.completion-percentage-small{background:#f0f4ff;border-radius:4px;color:#667eea;font-size:11px;font-weight:600;padding:2px 6px;text-align:center;white-space:nowrap}.btn-edit-client{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;margin-left:10px;padding:6px 12px;transition:all .3s}.btn-edit-client:hover{background:#2563eb;transform:scale(1.1)}.btn-delete-client{background:#c0bdbd;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;margin-left:10px;padding:6px 12px;transition:all .3s}.btn-delete-client:hover{background:#dc2626;transform:scale(1.1)}.contact-form{background:#fff;display:flex;flex-direction:column;gap:14px;max-height:calc(80vh - 120px);overflow-y:auto;padding:20px}.contact-form .form-group{margin-bottom:6px}.contact-form .form-group label{color:#475569;display:block;font-weight:600;margin-bottom:6px}.contact-form .form-group input{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:10px 12px;transition:border .2s;width:100%}.contact-form .form-group input:focus{border-color:#667eea;box-shadow:0 4px 12px #667eea1f;outline:none}.contact-form .form-group small{color:#64748b;display:block;font-size:12px;margin-top:6px}.form-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:6px}.btn-secondary{background:#fff;border:2px solid #cbd5e1;padding:10px 16px;transition:all .15s}.btn-secondary:hover{background:#f8fafc;transform:translateY(-2px)}@media (max-width:480px){.form-actions{flex-direction:column-reverse;justify-content:stretch}.form-actions .btn-primary,.form-actions .btn-secondary{width:100%}}.view-mode-toggle{background:#f8fafc;border-radius:8px;display:flex;gap:10px;margin:0 10px;padding:8px}.view-mode-btn{background:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s}.view-mode-btn:hover{background:#f1f5f9;transform:translateY(-1px)}.view-mode-btn.active{background:#667eea;border-color:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff}.vista-anual{margin:0 auto;max-width:1600px;padding:20px}.cargando-anual{color:#64748b;font-size:18px;padding:60px 20px;text-align:center}.estadisticas-globales{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:20px;padding:24px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.stat-card .stat-icon{font-size:48px;opacity:.9}.stat-card .stat-content{flex:1 1}.stat-card .stat-label{color:#64748b;font-size:14px;font-weight:500;margin-bottom:4px}.stat-card .stat-value{font-size:36px;font-weight:700;margin-bottom:4px}.stat-card .stat-detail{color:#94a3b8;font-size:13px}.stat-card.verde .stat-value{color:#10b981}.stat-card.amarillo .stat-value{color:#f59e0b}.stat-card.rojo .stat-value{color:#ef4444}.stat-card.azul .stat-value{color:#667eea}.tabla-anual-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px}.seccion-titulo{border-bottom:3px solid #667eea;color:#1e293b;font-size:24px;font-weight:700;margin-bottom:24px;padding-bottom:12px}.tabla-anual{display:flex;flex-direction:column;gap:20px}.cliente-anual-row{grid-gap:20px;align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:grid;gap:20px;grid-template-columns:250px 1fr 600px 120px;padding:20px;transition:all .2s}.cliente-anual-row:hover{background:#f1f5f9;border-color:#cbd5e1;box-shadow:0 2px 8px #00000014}.cliente-info{display:flex;flex-direction:column;gap:6px}.cliente-nombre{color:#1e293b;font-size:16px;font-weight:700}.cliente-meta{color:#64748b;font-size:13px}.progreso-container{display:flex;flex-direction:column;gap:10px}.progreso-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.progreso-porcentaje{color:#1e293b;font-size:20px;font-weight:700}.progreso-detalle{color:#64748b;font-size:13px}.progress-bar{background:#e2e8f0;border-radius:12px;display:flex;height:24px;overflow:hidden;position:relative}.progress-bar-fill{align-items:center;color:#fff;display:flex;font-size:11px;font-weight:700;height:100%;justify-content:center;transition:width .3s ease}.progress-bar-fill.verde{background:linear-gradient(90deg,#10b981,#059669)}.progress-bar-fill.amarillo{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-bar-fill.rojo{background:linear-gradient(90deg,#ef4444,#dc2626)}.estados-resumen{align-items:center;display:flex;gap:12px}.estado-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:13px;font-weight:600;gap:4px;padding:4px 10px}.estado-badge.verde{background:#d1fae5;color:#065f46}.estado-badge.amarillo{background:#fef3c7;color:#92400e}.estado-badge.rojo{background:#fee2e2;color:#991b1b}.heatmap-container{overflow-x:auto}.heatmap-meses{display:flex;gap:6px;min-width:-webkit-max-content;min-width:max-content}.mes-indicator{align-items:center;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:700;height:45px;justify-content:center;transition:all .2s;-webkit-user-select:none;user-select:none;width:45px}.mes-indicator:hover{box-shadow:0 4px 12px #0003;transform:scale(1.1)}.mes-indicator.verde{background:#10b981}.mes-indicator.amarillo{background:#f59e0b}.mes-indicator.rojo{background:#ef4444}.mes-indicator.gris{background:#cbd5e1;color:#64748b}.acciones-anual{align-items:center;display:flex;justify-content:center}.btn-ver-detalle-anual{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.btn-ver-detalle-anual:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.modal-detalle-anual{max-height:90vh;max-width:900px;overflow-y:auto}.detalle-resumen{grid-gap:16px;background:#f8fafc;border-radius:8px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px;padding:20px}.detalle-stat{display:flex;flex-direction:column;gap:6px}.detalle-label{color:#64748b;font-size:13px;font-weight:500}.detalle-value{font-size:28px;font-weight:700}.detalle-value.verde{color:#10b981}.detalle-value.amarillo{color:#f59e0b}.detalle-value.rojo{color:#ef4444}.detalle-seccion-titulo{color:#1e293b;font-size:18px;font-weight:700;margin-bottom:16px;margin-top:20px}.detalle-tabla-meses{margin-bottom:20px;overflow-x:auto}.tabla-detalle-mensual{border-collapse:collapse;font-size:14px;width:100%}.tabla-detalle-mensual thead{background:#f1f5f9}.tabla-detalle-mensual th{border-bottom:2px solid #cbd5e1;color:#475569;font-weight:600;padding:12px;text-align:left}.tabla-detalle-mensual td{border-bottom:1px solid #e2e8f0;padding:12px}.tabla-detalle-mensual tbody tr:hover{background:#f8fafc}.tabla-detalle-mensual .mes-nombre{color:#1e293b;font-weight:600}.tabla-detalle-mensual .numero{font-weight:600;text-align:center}.tabla-detalle-mensual .numero.verde{color:#10b981}.tabla-detalle-mensual .numero.amarillo{color:#f59e0b}.tabla-detalle-mensual .numero.rojo{color:#ef4444}.porcentaje-container{background:#e2e8f0;border-radius:4px;height:24px;overflow:hidden;position:relative;width:100%}.porcentaje-bar{background:linear-gradient(90deg,#10b981,#059669);height:100%;left:0;position:absolute;top:0;transition:width .3s ease}.porcentaje-texto{color:#1e293b;font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:1}.detalle-acciones{border-top:1px solid #e2e8f0;display:flex;justify-content:center;padding-top:20px}.btn-exportar-pdf-anual{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 32px;transition:all .2s}.btn-exportar-pdf-anual:hover{box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}@media (max-width:1400px){.cliente-anual-row{gap:16px;grid-template-columns:1fr}.heatmap-meses{flex-wrap:wrap;justify-content:center}.acciones-anual{justify-content:flex-start}}@media (max-width:768px){.estadisticas-globales{grid-template-columns:1fr}.stat-card{padding:20px}.stat-card .stat-icon{font-size:36px}.stat-card .stat-value{font-size:28px}.tabla-anual-container{padding:20px}.view-mode-toggle{flex-direction:column;gap:6px}.view-mode-btn{width:100%}.mes-indicator{font-size:10px;height:40px;width:40px}}.badge-pendientes{background:#ef4444;border-radius:10px;font-weight:600;padding:2px 6px}.badge-pendientes,.notification-badge{color:#fff;font-size:11px;margin-left:8px}.notification-badge{align-items:center;animation:pulse-notification 2s infinite;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;box-shadow:0 2px 4px #ef444466;display:inline-flex;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 5px}@keyframes pulse-notification{0%,to{box-shadow:0 2px 4px #ef444466;transform:scale(1)}50%{box-shadow:0 2px 8px #ef444499;transform:scale(1.1)}}.solicitudes-lista{gap:15px;max-height:500px;overflow-y:auto}.solicitud-card{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;justify-content:space-between;padding:20px;transition:all .2s}.solicitud-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.solicitud-info h4{color:#1e293b;font-size:18px;margin:0 0 10px}.solicitud-info p{color:#64748b;font-size:14px;margin:5px 0}.solicitud-info p strong{color:#475569}.solicitud-mes{color:#667eea!important;font-size:16px!important;font-weight:600!important}.solicitud-motivo{background:#fff;border-radius:8px;font-style:italic;margin-top:10px;padding:10px}.solicitud-acciones{display:flex;flex-shrink:0;gap:10px}.solicitud-acciones button{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.solicitud-acciones .btn-success{background:#10b981;color:#fff}.solicitud-acciones .btn-success:hover{background:#059669}.solicitud-acciones .btn-danger{background:#ef4444;color:#fff}.solicitud-acciones .btn-danger:hover{background:#dc2626}.modal-content.large{max-width:800px;width:90%}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.btn-secondary{background:#e2e8f0;border:none;border-radius:8px;color:#475569;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.btn-secondary:hover{background:#cbd5e1}.btn-primary{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.btn-primary:hover{background:#5568d3}.loading-spinner{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#667eea;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-spinner p{color:#64748b;font-size:14px;margin-top:20px}.estado-wrapper{display:inline-block;position:relative}.warning-badge{align-items:center;animation:pulse-warning 2s infinite;background:#ffe36c;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;cursor:help;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;position:absolute;right:-8px;top:-8px;width:20px;z-index:10}@keyframes pulse-warning{0%{box-shadow:0 2px 4px #ef444466;transform:scale(1)}50%{box-shadow:0 4px 8px #ef444499;transform:scale(1.1)}to{box-shadow:0 2px 4px #ef444466;transform:scale(1)}}.estado-container-table{align-items:center;display:flex;flex-direction:column;gap:3px}.estado-fecha-table{color:#64748b;display:block;font-size:9px;text-align:center;white-space:nowrap}.cell-estado{padding:8px;position:relative;text-align:center}.permiso-modal{animation:modalSlideIn .3s ease-out;max-width:550px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.permiso-header{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:12px 12px 0 0;color:#fff;display:flex;gap:12px;margin:-20px -20px 0;padding:24px}.permiso-icon{animation:lockShake .5s ease-in-out;font-size:32px}@keyframes lockShake{0%,to{transform:rotate(0deg)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.permiso-header h2{flex:1 1;font-size:22px;margin:0}.permiso-info-box{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-left:4px solid #ef4444;border-radius:8px;margin:20px 0;padding:20px}.permiso-mensaje{color:#374151;font-size:16px;line-height:1.5;margin-bottom:12px}.mes-destacado{color:#dc2626;font-size:18px;text-decoration:underline;-webkit-text-decoration-color:#fca5a5;text-decoration-color:#fca5a5}.permiso-descripcion{color:#6b7280;font-size:14px;line-height:1.6;margin:0}.permiso-form{margin-top:20px}.permiso-label{align-items:center;color:#374151;display:flex;font-size:15px;font-weight:600;gap:8px;margin-bottom:8px}.opcional-tag{background:#e5e7eb;border-radius:12px;color:#6b7280;font-size:11px;font-weight:500;padding:2px 8px}.permiso-textarea{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;padding:12px;resize:vertical;transition:all .2s;width:100%}.permiso-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.permiso-note{align-items:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;display:flex;font-size:13px;gap:8px;margin-top:16px;padding:12px}.note-icon{font-size:18px}.admin-permisos-panel{max-width:700px}.admin-permisos-header{background:linear-gradient(135deg,#3b82f6,#1e40af);border-radius:12px 12px 0 0;color:#fff;margin:-20px -20px 0;padding:24px}.header-content{align-items:center;display:flex;gap:12px}.header-icon{font-size:32px}.admin-permisos-header h2{font-size:22px;margin:0}.empty-state{padding:60px 20px;text-align:center}.empty-icon{display:block;font-size:64px;margin-bottom:16px}.empty-state p{color:#374151;font-size:16px;margin:8px 0}.empty-subtitle{color:#9ca3af;font-size:14px}.solicitudes-lista-compacta{display:flex;flex-direction:column;gap:12px;padding:0}.solicitud-card-compacta{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;display:flex;justify-content:space-between;padding:14px 16px;transition:all .2s}.solicitud-card-compacta:hover{background:#f3f4f6;border-color:#3b82f6}.solicitud-info-compacta{display:flex;flex:1 1;flex-direction:column;gap:4px}.info-principal{align-items:center;display:flex;gap:12px}.usuario-nombre{color:#1f2937;font-size:15px;font-weight:600}.solicitud-mes-compacto{background:#dbeafe;border-radius:12px;color:#1e40af;font-size:13px;font-weight:500;padding:3px 10px}.info-secundaria{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.fecha-small{color:#6b7280;font-size:13px}.motivo-preview{color:#9ca3af;font-size:13px;font-style:italic}.solicitud-acciones-compacta{display:flex;gap:8px;margin-left:16px}.btn-rechazar-compacto{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#dc2626;cursor:pointer;font-size:13px;font-weight:500;padding:8px 14px;transition:all .2s}.btn-rechazar-compacto:hover{background:#fee2e2;border-color:#f87171}.btn-aprobar-compacto{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 14px;transition:all .2s}.btn-aprobar-compacto:hover{background:linear-gradient(135deg,#16a34a,#15803d);transform:translateY(-1px)}.solicitudes-lista{display:flex;flex-direction:column;gap:20px;margin-top:20px}.solicitud-card-nueva{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px;transition:all .2s}.solicitud-card-nueva:hover{border-color:#3b82f6;box-shadow:0 4px 12px #00000026}.solicitud-header-card{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.usuario-info{gap:12px}.usuario-avatar,.usuario-info{align-items:center;display:flex}.usuario-avatar{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;font-size:24px;height:48px;justify-content:center;width:48px}.usuario-info h4{color:#111827;font-size:16px;margin:0}.usuario-username{color:#6b7280;display:block;font-size:13px;margin-top:2px}.solicitud-badge{background:#fef3c7;border-radius:12px;color:#92400e;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 12px}.solicitud-detalles{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.detalle-item{align-items:flex-start;display:flex;gap:12px}.detalle-icon{flex-shrink:0;font-size:20px}.detalle-item>div{flex:1 1}.detalle-label{color:#9ca3af;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:2px;text-transform:uppercase}.detalle-valor{color:#111827;display:block;font-size:15px;font-weight:500}.motivo-completo{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:12px}@keyframes pulse-azul-verde{0%,to{box-shadow:0 0 0 3px #3b82f633}50%{box-shadow:0 0 0 6px #3b82f61a}}.cliente-info-detalle{padding:20px}.info-section{margin-bottom:30px}.info-section h3{border-bottom:2px solid #e5e7eb;color:#111827;font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:8px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{display:flex;flex-direction:column;gap:6px}.info-item label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#111827;display:flex;font-size:15px;min-height:40px;padding:10px 12px}.notas-admin-section{margin-top:30px}.notas-admin-section h3{color:#111827;font-size:18px;font-weight:600;margin-bottom:8px}.notas-descripcion{color:#6b7280;font-size:13px;line-height:1.5;margin-bottom:12px}.notas-actions{align-items:center;display:flex;gap:12px}.nota-readonly{color:#9ca3af;font-size:13px;font-style:italic;margin:0}.btn-guardar-notas{margin-top:0!important}.notas-admin-textarea{border:2px solid #e5e7eb;border-radius:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;min-height:120px;padding:12px;resize:vertical;transition:border-color .2s;width:100%}.notas-admin-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.notas-admin-section button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:12px;padding:10px 20px;transition:all .2s}.notas-admin-section button:hover{box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.notas-admin-section button:active{transform:translateY(0)}.historial-notas-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:28px;padding:20px}.historial-notas-titulo h3{align-items:center;color:#111827;display:flex;font-size:16px;font-weight:600;gap:10px;margin:0 0 16px}.historial-count-badge{background:#3b82f6;border-radius:999px;color:#fff;font-size:12px;font-weight:700;padding:2px 10px}.historial-form{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:16px;padding:12px}.historial-lista{display:flex;flex-direction:column;gap:10px}.toast-reconectando{align-items:center;animation:slideDown .3s ease-out;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:8px;box-shadow:0 4px 20px #0003;color:#fff;display:flex;gap:12px;left:50%;padding:12px 24px;position:fixed;top:20px;transform:translateX(-50%);z-index:9999}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.toast-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.toast-reconectando span{font-size:14px;font-weight:500}.cobranza-btn{background:#ffffff1a;border:1px solid #ffffff59;border-radius:10px;color:#fff;cursor:pointer;font-weight:700;padding:10px 16px}.cobranza-btn.active{background:#22c55e;border-color:#22c55e;color:#083344}.cobranza-wrapper{width:100%}.cobranza-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px}.cobranza-header h2{margin:0 0 6px}.cobranza-header p{color:#475569;margin:0}.btn-envio-masivo{background:#16a34a;border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;padding:10px 18px;white-space:nowrap}.btn-envio-masivo:disabled{background:#86efac;cursor:not-allowed}.cobranza-input{min-width:110px}.cobranza-table tfoot tr td{background:#f8fafc;padding:10px 12px}.cobranza-table td,.cobranza-table th{vertical-align:middle}.cobranza-input,.cobranza-select{border:1px solid #cbd5e1;border-radius:8px;padding:8px;width:100%}.btn-generar-link{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:8px 12px}.modal-cobranza{max-width:520px}.btn-efectivo{background:#f59e0b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;margin-left:6px;padding:6px 12px}.btn-efectivo:hover{background:#d97706}.modal-efectivo{max-width:460px;width:100%}.efectivo-lista{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.efectivo-item{align-items:center;background:#f8fafc;border-radius:6px;cursor:pointer;display:flex;gap:10px;padding:8px 10px}.efectivo-item input[type=checkbox]{cursor:pointer;height:16px;width:16px}.efectivo-concepto{flex:1 1;font-size:13px}.efectivo-monto{color:#dc2626;font-size:13px;font-weight:600}.efectivo-nota{border:1px solid #e5e7eb;border-radius:6px;box-sizing:border-box;font-size:13px;margin-bottom:10px;padding:8px 10px;width:100%}.efectivo-total{font-size:14px;font-weight:700;margin-bottom:12px}.btn-confirmar-efectivo{background:#16a34a;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;width:100%}.btn-confirmar-efectivo:disabled{background:#9ca3af;cursor:not-allowed}.btn-confirmar-efectivo:hover:not(:disabled){background:#15803d}.modal-cobranza p{margin-bottom:12px}
/*# sourceMappingURL=main.04b00ae5.css.map*/