.comunicados-page{padding:24px;max-width:1200px;margin:0 auto}.comunicados-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px;flex-wrap:wrap}.comunicados-header-left{display:flex;align-items:flex-start;gap:16px}.comunicados-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-strong) 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.comunicados-header h1{margin:0;font-size:24px;font-weight:700;color:var(--sidebar-text, #1e293b)}.comunicados-subtitle{margin:4px 0 0;font-size:14px;color:var(--muted)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-icon.danger:hover{background:#fef2f2;color:#ef4444}.btn-sm{padding:6px 12px;font-size:13px}.btn-xs{padding:4px}.comunicados-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filter-buttons{display:flex;gap:8px}.filter-btn{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--muted);cursor:pointer;transition:all .2s ease}.filter-btn:hover,.filter-btn.active{border-color:var(--primary);color:var(--primary)}.filter-btn svg.rotated{transform:rotate(180deg)}.comunicados-stats-row{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.stat-card{display:flex;flex-direction:column;padding:16px 24px;background:#fff;border-radius:12px;border:1px solid var(--border);min-width:120px}.stat-value{font-size:28px;font-weight:700;color:var(--sidebar-text, #1e293b)}.stat-value.draft{color:#f59e0b}.stat-value.published{color:var(--success)}.stat-label{font-size:13px;color:var(--muted);margin-top:4px}.comunicados-list{display:flex;flex-direction:column;gap:16px}.comunicados-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;background:#fff;border-radius:16px;border:1px solid var(--border);color:var(--muted);text-align:center}.comunicados-empty svg{opacity:.4;margin-bottom:16px}.comunicados-empty h3{margin:0 0 8px;color:var(--sidebar-text, #1e293b)}.comunicados-empty p{margin:0 0 20px;max-width:300px}.comunicado-card{background:#fff;border-radius:16px;border:1px solid var(--border);padding:20px;transition:all .2s ease}.comunicado-card:hover{box-shadow:0 4px 12px #0000000d}.comunicado-card.urgent{border-left:4px solid #ef4444}.comunicado-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.comunicado-badges{display:flex;gap:8px;flex-wrap:wrap}.status-badge.draft{background:#fef3c7;color:#d97706}.status-badge.published{background:#dcfce7;color:#16a34a}.status-badge.urgent{background:#fef2f2;color:#ef4444}.status-badge.ack{background:#ede9fe;color:#7c3aed}.comunicado-code{font-size:12px;color:var(--muted);font-family:monospace}.comunicado-title{margin:0 0 12px;font-size:18px;font-weight:600;color:var(--sidebar-text, #1e293b)}.comunicado-meta{display:flex;gap:20px;margin-bottom:16px;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}.comunicado-stats{display:flex;align-items:center;gap:16px;padding:12px 0;border-top:1px solid var(--border);margin-bottom:12px}.read-progress{flex:1;display:flex;align-items:center;gap:12px}.progress-bar{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;max-width:200px}.progress-bar.large{height:8px;max-width:none}.progress-fill{height:100%;background:var(--success);border-radius:3px;transition:width .3s ease}.progress-text{font-size:13px;color:var(--muted);white-space:nowrap}.ack-count{font-size:13px;color:#7c3aed;white-space:nowrap}.comunicado-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border)}.modal-sm{max-width:400px}.modal-xl{max-width:900px}.header-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.header-badges{display:flex;gap:8px}.modal-tabs{display:flex;padding:0 24px;border-bottom:1px solid var(--border);background:#f8fafc}.tab{display:flex;align-items:center;gap:8px;padding:14px 20px;background:none;border:none;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;position:relative;transition:color .2s ease}.tab:hover{color:var(--sidebar-text, #1e293b)}.tab.active{color:var(--primary)}.tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--primary)}.modal-body p{margin:0 0 12px;color:var(--sidebar-text, #1e293b)}.modal-body .text-muted{color:var(--muted);font-size:13px}.form-group{margin-bottom:20px}.form-group label{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--sidebar-text, #1e293b)}.form-group input[type=text],.form-group input[type=datetime-local],.form-group textarea,.form-group select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;transition:all .2s ease;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-group input.error,.form-group textarea.error{border-color:#ef4444}.form-group textarea{resize:vertical;min-height:150px}.error-text{display:block;margin-top:6px;font-size:13px;color:#ef4444}.help-text{display:block;margin-top:6px;font-size:13px;color:var(--muted)}.form-row{display:flex;gap:24px;margin-bottom:20px;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--sidebar-text, #1e293b);cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.checkbox-label svg{color:var(--muted)}.checkbox-label .icon-urgent{color:#ef4444}.checkbox-label.highlight{padding:12px 16px;background:#f8fafc;border-radius:10px;border:1px solid var(--border)}.form-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}.form-section h3{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:16px;font-weight:600}.assignments-section{margin-top:16px}.assignments-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.assignment-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 8px 6px 12px;background:#f1f5f9;border-radius:8px;font-size:13px}.assignment-type{color:var(--muted)}.assignment-name{font-weight:500}.assignment-picker{background:#f8fafc;border-radius:10px;padding:12px;border:1px solid var(--border)}.picker-row{display:flex;gap:8px;flex-wrap:wrap}.picker-type{width:120px}.picker-value{flex:1;min-width:150px}.detail-content{display:flex;flex-direction:column;gap:24px}.detail-meta{display:flex;flex-wrap:wrap;gap:16px;padding:16px;background:#f8fafc;border-radius:12px}.detail-meta .meta-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--sidebar-text, #1e293b)}.detail-meta .meta-item svg{color:var(--muted)}.detail-meta .meta-item.highlight{color:#7c3aed}.detail-meta .meta-item.highlight svg{color:#7c3aed}.detail-recipients-summary{padding:16px;background:#fff;border:1px solid var(--border);border-radius:12px}.detail-recipients-summary h4{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:14px;font-weight:600}.recipients-badges{display:flex;flex-wrap:wrap;gap:8px}.recipient-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#f1f5f9;border-radius:6px;font-size:13px}.recipient-badge.all{background:var(--primary);color:#fff}.no-recipients{color:var(--muted);font-size:13px}.detail-progress{padding:16px;background:#fff;border:1px solid var(--border);border-radius:12px}.progress-header{display:flex;justify-content:space-between;margin-bottom:12px;font-size:14px;font-weight:600}.progress-value{color:var(--success)}.progress-stats{display:flex;justify-content:space-between;margin-top:12px;font-size:13px;color:var(--muted)}.detail-body{padding:20px;background:#fff;border:1px solid var(--border);border-radius:12px}.detail-body h4{margin:0 0 16px;font-size:14px;font-weight:600;color:var(--muted)}.comunicado-content-preview{font-size:15px;line-height:1.7;color:var(--sidebar-text, #1e293b)}.comunicado-content-preview p{margin:0 0 16px}.detail-recipients{display:flex;flex-direction:column;gap:20px}.recipients-filters{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s ease}.filter-chip:hover{border-color:var(--primary)}.filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.recipients-table{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}.table-header{display:flex;padding:12px 16px;background:#f8fafc;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.table-body{max-height:400px;overflow-y:auto}.table-row{display:flex;padding:14px 16px;border-top:1px solid var(--border);align-items:center}.table-row:first-child{border-top:none}.col-name{flex:1;display:flex;align-items:center;gap:10px;font-size:14px}.col-status{width:120px}.col-date{width:140px;font-size:13px;color:var(--muted)}.col-ack{width:160px}.avatar-sm{width:32px;height:32px;border-radius:8px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.status-indicator{display:inline-flex;align-items:center;gap:4px;font-size:13px}.status-indicator.read{color:var(--success)}.status-indicator.unread{color:var(--muted)}.status-indicator.acknowledged{color:#7c3aed}.status-indicator.pending{color:var(--muted)}.detail-stats{display:flex;flex-direction:column;gap:32px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-box{display:flex;align-items:center;gap:16px;padding:20px;background:#fff;border:1px solid var(--border);border-radius:12px}.stat-box .stat-icon{width:48px;height:48px;border-radius:12px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:var(--muted)}.stat-box.success .stat-icon{background:#dcfce7;color:#16a34a}.stat-box.warning .stat-icon{background:#fef3c7;color:#d97706}.stat-box.primary .stat-icon{background:#ede9fe;color:#7c3aed}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:28px;font-weight:700;color:var(--sidebar-text, #1e293b);line-height:1}.stat-box .stat-label{font-size:13px;color:var(--muted);margin-top:4px}.stats-progress-section{display:flex;flex-wrap:wrap;gap:32px;align-items:flex-start}.stats-progress-section h4{width:100%;margin:0 0 -16px;font-size:14px;font-weight:600;color:var(--sidebar-text, #1e293b)}.stats-progress-section h4:not(:first-child){margin-top:16px}.circular-progress{position:relative;width:160px;height:160px}.circular-progress svg{transform:rotate(-90deg)}.circular-progress circle{fill:none;stroke-width:8;stroke-linecap:round}.circular-progress circle.bg{stroke:#e2e8f0}.circular-progress circle.fill{stroke:var(--success);transition:stroke-dasharray .5s ease}.circular-progress circle.fill.ack{stroke:#7c3aed}.progress-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.progress-center .percentage{font-size:32px;font-weight:700;color:var(--sidebar-text, #1e293b)}.progress-center .label{font-size:13px;color:var(--muted)}.comunicados-page.employee{padding:20px;max-width:800px;margin:0 auto}.comunicados-page.employee .comunicados-header{margin-bottom:20px}.comunicado-item{display:flex;align-items:center;gap:12px;width:100%;padding:16px 20px;background:#fff;border:1px solid var(--border);border-radius:14px;text-align:left;cursor:pointer;transition:all .2s ease;margin-bottom:12px}.comunicado-item:hover{border-color:var(--primary);box-shadow:0 4px 12px #4f46e51a}.comunicado-item.unread{background:#f8faff;border-color:var(--primary);border-left:4px solid var(--primary)}.comunicado-item.urgent{border-left-color:#ef4444}.comunicado-item-content{flex:1;min-width:0}.comunicado-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:12px;flex-wrap:wrap}.comunicado-badges{display:flex;gap:6px;flex-wrap:wrap}.badge.urgent{background:#fef2f2;color:#dc2626}.badge.ack-pending{background:#fef3c7;color:#92400e}.badge.ack-done{background:#dcfce7;color:#16a34a}.comunicado-date{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--muted);white-space:nowrap}.comunicado-item .comunicado-title{font-size:15px;font-weight:600;color:var(--sidebar-text, #1e293b);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comunicado-arrow{flex-shrink:0;color:var(--muted);opacity:.5;transition:all .2s ease}.comunicado-item:hover .comunicado-arrow{opacity:1;transform:translate(4px)}.comunicado-detail-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;margin-bottom:20px}.status-badge.ack-pending{background:#fef3c7;color:#92400e}.status-badge.ack-done{background:#dcfce7;color:#16a34a}.comunicado-content-body{padding:20px;background:#fff;border:1px solid var(--border);border-radius:12px;font-size:15px;line-height:1.7;color:var(--sidebar-text, #1e293b)}.comunicado-content-body p{margin:0 0 16px}.comunicado-content-body p:last-child{margin-bottom:0}.comunicado-content-body ul,.comunicado-content-body ol{margin:0 0 16px;padding-left:24px}.comunicado-content-body li{margin-bottom:8px}.comunicado-content-body strong{font-weight:600}.comunicado-read-info{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);font-size:13px}.read-status,.ack-status{display:flex;align-items:center;gap:6px;color:var(--muted)}.ack-status{color:#16a34a}@media (max-width: 768px){.comunicados-page{padding:16px}.comunicados-header{flex-direction:column;align-items:stretch}.comunicados-header .btn-primary{justify-content:center}.comunicados-filters{flex-direction:column}.search-container{max-width:none}.comunicados-stats-row{flex-direction:column}.stat-card{flex-direction:row;align-items:center;gap:12px}.modal{max-height:100vh;border-radius:0}.modal-body{padding:16px}.form-row{flex-direction:column;gap:12px}.picker-row{flex-direction:column}.picker-type,.picker-value{width:100%}.table-header,.table-row{font-size:12px}.col-date,.col-ack{display:none}.stats-grid{grid-template-columns:1fr}}.documents-page{padding:24px;max-width:1200px;margin:0 auto}.documents-page.employee{padding:20px;max-width:800px;margin:0 auto}.documents-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px;flex-wrap:wrap}.documents-header-left{display:flex;align-items:flex-start;gap:16px}.documents-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-strong) 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.documents-header h1{margin:0;font-size:24px;font-weight:700;color:var(--sidebar-text, #1e293b)}.documents-subtitle{margin:4px 0 0;font-size:14px;color:var(--muted)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s ease}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-strong)}.btn-primary:disabled{background:#cbd5e1;cursor:not-allowed}.btn-secondary{background:#f1f5f9;color:var(--sidebar-text, #1e293b);border:1px solid var(--border)}.btn-secondary:hover{background:#e2e8f0}.btn-icon{padding:8px;background:transparent;color:var(--muted)}.btn-icon:hover{background:#f1f5f9;color:var(--sidebar-text, #1e293b)}.documents-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.search-container{position:relative;flex:1;min-width:250px;max-width:400px}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted)}.search-input{width:100%;padding:10px 40px;border:1px solid var(--border);border-radius:10px;font-size:14px;background:#fff;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:4px}.search-clear:hover{background:#f1f5f9}.filter-chips{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:1px solid var(--border);border-radius:20px;font-size:13px;color:var(--muted);cursor:pointer;transition:all .2s ease}.chip:hover{border-color:var(--primary)}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.unread-badge{background:var(--primary);color:#fff;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600}.pending-alert{display:flex;align-items:center;gap:10px;padding:14px 18px;background:#fef3c7;border:1px solid #fbbf24;border-radius:12px;margin-bottom:20px;font-size:14px;color:#92400e}.pending-alert svg{flex-shrink:0;color:#d97706}.documents-list{display:flex;flex-direction:column;gap:12px}.documents-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;background:#fff;border-radius:16px;border:1px solid var(--border);color:var(--muted);text-align:center}.documents-empty svg{opacity:.4;margin-bottom:16px}.documents-empty h3{margin:0 0 8px;color:var(--sidebar-text, #1e293b)}.documents-empty p{margin:0 0 20px;max-width:300px}.document-item{display:flex;align-items:center;gap:12px;width:100%;padding:16px 20px;background:#fff;border:1px solid var(--border);border-radius:14px;text-align:left;cursor:pointer;transition:all .2s ease}.document-item:hover{border-color:var(--primary);box-shadow:0 4px 12px #4f46e51a}.document-item.unread{background:#f8faff;border-color:var(--primary);border-left:4px solid var(--primary)}.document-item.pending-sign{border-left-color:#f59e0b}.document-item-content{flex:1;min-width:0}.document-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:12px;flex-wrap:wrap}.document-badges{display:flex;gap:6px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600}.badge.new{background:var(--primary);color:#fff}.badge.sign-pending{background:#fef3c7;color:#92400e}.badge.signed{background:#dcfce7;color:#16a34a}.badge.expiring{background:#fef2f2;color:#dc2626}.badge.sensitivity-green{background:#dcfce7;color:#16a34a}.badge.sensitivity-blue{background:#dbeafe;color:#2563eb}.badge.sensitivity-amber{background:#fef3c7;color:#d97706}.badge.sensitivity-red{background:#fef2f2;color:#dc2626}.document-date{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--muted);white-space:nowrap}.document-title{font-size:15px;font-weight:600;color:var(--sidebar-text, #1e293b);margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.document-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--muted)}.document-code{font-family:monospace;background:#f1f5f9;padding:2px 6px;border-radius:4px}.document-arrow{flex-shrink:0;color:var(--muted);opacity:.5;transition:all .2s ease}.document-item:hover .document-arrow{opacity:1;transform:translate(4px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:16px;width:100%;max-height:calc(100vh - 48px);display:flex;flex-direction:column;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-lg{max-width:700px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);gap:16px}.modal-header-title{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.modal-header-title h2{margin:0;font-size:18px;font-weight:600}.modal-header-title svg{color:var(--primary);flex-shrink:0}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border)}.document-detail-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;margin-bottom:20px}.meta-badges{display:flex;gap:8px}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600}.status-badge.sign-pending{background:#fef3c7;color:#92400e}.status-badge.signed,.status-badge.sensitivity-green{background:#dcfce7;color:#16a34a}.status-badge.sensitivity-blue{background:#dbeafe;color:#2563eb}.status-badge.sensitivity-amber{background:#fef3c7;color:#d97706}.status-badge.sensitivity-red{background:#fef2f2;color:#dc2626}.meta-date{font-size:13px;color:var(--muted)}.document-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:20px;padding:16px;background:#fff;border:1px solid var(--border);border-radius:12px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{font-size:12px;color:var(--muted);font-weight:500}.info-item span{font-size:14px;color:var(--sidebar-text, #1e293b);font-weight:500}.info-item span.text-amber{color:#d97706}.document-description{padding:16px;background:#fff;border:1px solid var(--border);border-radius:12px;margin-bottom:20px}.document-description h4{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--muted)}.document-description p{margin:0;font-size:14px;line-height:1.6;color:var(--sidebar-text, #1e293b)}.document-status-info{display:flex;flex-wrap:wrap;gap:16px;padding-top:16px;border-top:1px solid var(--border);font-size:13px}.read-status,.sign-status{display:flex;align-items:center;gap:6px;color:var(--muted)}.read-status svg{color:var(--primary)}.sign-status{color:#16a34a}.documents-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:var(--muted)}.documents-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.documents-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;background:#fff;border-radius:16px;border:1px solid var(--border);color:var(--muted);text-align:center}.documents-error svg{color:#ef4444;margin-bottom:16px}.documents-error h3{margin:0 0 8px;color:var(--sidebar-text, #1e293b)}.documents-error p{margin:0 0 20px}@media (max-width: 768px){.documents-page{padding:16px}.documents-header{flex-direction:column;align-items:stretch}.documents-filters{flex-direction:column}.search-container{max-width:none}.filter-chips{overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px}.chip{white-space:nowrap}.modal{max-height:100vh;border-radius:0}.modal-body{padding:16px}.document-info-grid{grid-template-columns:1fr 1fr}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.relative{position:relative}.left-0{left:0}.left-3{left:.75rem}.right-0{right:0}.right-3{right:.75rem}.top-1\/2{top:50%}.top-full{top:100%}.z-50{z-index:50}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.ml-auto{margin-left:auto}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-8{margin-top:2rem}.flex{display:flex}.inline-flex{display:inline-flex}.h-16{height:4rem}.max-h-60{max-height:15rem}.min-h-screen{min-height:100vh}.w-16{width:4rem}.w-full{width:100%}.min-w-0{min-width:0px}.max-w-md{max-width:28rem}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-spin{animation:spin 1s linear infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-gray-100{--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-red-100{--tw-border-opacity: 1;border-color:rgb(254 226 226 / var(--tw-border-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-indigo-100{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))}.bg-indigo-50{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pl-10{padding-left:2.5rem}.pr-12{padding-right:3rem}.pr-4{padding-right:1rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.italic{font-style:italic}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.text-indigo-700{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--bg: #F3F4F6;--panel: #ffffff;--primary: #4F46E5;--primary-strong: #4338CA;--muted: #5b6478;--border: #dfe5f2;--accent: #ffb347;--success: #0f9d58;--radius: 18px;--sidebar: 280px;--sidebar-collapsed: 84px;--sidebar-text: #1d2433;--sidebar-muted: #6a7690;font-family:Space Grotesk,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:#0f172a;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh;transition:grid-template-columns .25s ease}.app-shell.collapsed,.app-shell.mobile-collapsed,.app-shell.mobile-open{grid-template-columns:1fr}.sidebar{background:#fafbfc;color:var(--sidebar-text);padding:20px 16px 28px;display:flex;flex-direction:column;gap:10px;border-right:1px solid var(--border);transition:width .25s ease,padding .25s ease,transform .25s ease,opacity .2s ease;position:relative;justify-content:flex-start;align-items:stretch;height:100vh;overflow-y:auto}.sidebar.collapsed{align-items:center;transform:translate(-110%);opacity:0;pointer-events:none;position:absolute;width:var(--sidebar)}.sidebar.mobile{position:fixed;left:0;top:0;bottom:0;z-index:20;width:var(--sidebar);box-shadow:0 14px 34px #061d5559}.sidebar.mobile-hidden{transform:translate(-110%);box-shadow:none}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000047;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:15}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 16px 13px;border-bottom:1px solid var(--border)}.collapse-btn{background:#fff;border:1px solid var(--border);color:var(--sidebar-text);padding:8px;border-radius:12px;cursor:pointer;box-shadow:0 10px 24px #4f46e514}.sidebar h1{font-size:20px;letter-spacing:.2px;margin:0 0 2px;color:var(--sidebar-text)}.sidebar .tagline{font-size:12px;color:var(--sidebar-muted);margin:0 0 6px}.nav-group{display:flex;flex-direction:column;gap:2px;margin-bottom:15px;align-items:stretch}.nav-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--sidebar-muted);margin:6px 0 4px 10px}.nav-button{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;border:none;background:transparent;color:var(--sidebar-muted);cursor:pointer;text-align:left;font-size:14px;font-weight:500;transition:all .2s ease}.nav-button:hover{background:#fff9;color:var(--sidebar-text)}.nav-button.active{background:#ffffffd9;color:var(--primary);font-weight:600;box-shadow:0 2px 8px #0000000a}.nav-button.active .nav-icon{color:var(--primary)}.nav-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center}.sidebar.collapsed .nav-button{justify-content:center;padding:10px}.sidebar.collapsed .nav-button span:last-child{display:none}.sidebar.collapsed .nav-label{display:none}.mobile-toggle{display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px;cursor:pointer;box-shadow:0 8px 18px #0f172a1a}.header{padding:20px 28px 0;display:flex;align-items:center;gap:12px}.title{font-size:24px;margin:0 0 8px}.subtitle{margin:0;color:var(--muted)}.main{padding:20px 28px 28px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:start}.main:has(.chat-wrapper){display:flex;flex-direction:column;flex:1;min-height:0;padding-bottom:20px;width:100%}.chat-wrapper{width:320px;display:flex;min-height:0;height:100%;max-height:none;width:100%;padding:10px}.chat-shell{display:flex;flex:1;min-height:0;width:100%;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 12px 30px #0f172a0f}.chat-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:30}.chat-sidebar.drawer{position:fixed;inset:0 auto 0 0;width:320px;z-index:40;transform:translate(-110%);transition:transform .2s ease;border-radius:0;max-height:100vh;background:var(--panel);border-right:1px solid var(--border);box-shadow:0 12px 30px #0f172a29}.chat-sidebar.drawer.open{transform:translate(0)}.chat-hamburger{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;padding:8px;border-radius:10px;cursor:pointer;color:var(--muted)}.chat-hamburger:hover{background:var(--bg);color:var(--primary)}.card{background:var(--panel);border-radius:var(--radius);padding:18px;border:1px solid var(--border);box-shadow:0 12px 30px #0f172a0f}.card h3{margin:0 0 12px;font-size:16px}.card p{margin:0 0 10px;color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#0b5cff14;color:var(--primary);border-radius:10px;font-size:12px;font-weight:600}.pill-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.pill{padding:6px 10px;background:#eef2ff;color:#1e2a5a;border-radius:999px;font-size:12px;font-weight:600}.section-grid{display:grid;gap:10px}.section-item{padding:12px;border-radius:12px;border:1px solid var(--border);background:#fdfefe}.section-item strong{display:block;margin-bottom:6px}.chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.chip{padding:6px 10px;border-radius:10px;background:#eef2ff;color:#4f46e5;font-size:12px;font-weight:600}.footer-note{margin-top:14px;color:var(--muted);font-size:13px}.portal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--panel);border-bottom:1px solid var(--border);gap:16px}.header-left{display:flex;align-items:center;gap:16px}.header-menu-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:10px;padding:8px;cursor:pointer;color:var(--muted);transition:all .2s ease}.header-menu-btn:hover{background:var(--bg);color:var(--primary)}.header-logo{display:flex;align-items:center;gap:10px}.client-logo{height:36px;width:auto;-o-object-fit:contain;object-fit:contain}.logo-placeholder{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}.client-name{font-weight:600;font-size:15px;color:var(--sidebar-text)}.header-center{flex:1;text-align:center}.header-title{font-size:14px;color:var(--muted);font-weight:500}.header-right{display:flex;align-items:center;gap:8px}.api-status-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.api-status-icon.offline{color:#f59e0b}.api-status-icon.online{color:var(--muted);opacity:.6}.header-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;padding:10px;cursor:pointer;color:var(--muted);transition:all .2s ease}.header-icon-btn:hover{background:var(--bg);color:var(--primary)}.notification-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;background:#ea4335;color:#fff;border-radius:9px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center}.header-profile-btn{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:24px;padding:6px 12px 6px 6px;cursor:pointer;transition:all .2s ease}.header-profile-btn:hover{border-color:var(--primary)}.user-avatar{width:28px;height:28px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.avatar-placeholder.small{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center}.user-name{font-size:13px;font-weight:500;color:var(--sidebar-text)}.main-container{display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden}.page-header{padding:20px 28px 0}.main.full-width{padding:0}.home-page{padding:20px 28px 28px}.welcome-section{margin-bottom:24px}.welcome-section h2{font-size:24px;margin:0 0 6px;color:var(--sidebar-text)}.welcome-section p{margin:0;color:var(--muted)}.home-grid{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}.home-column{display:flex;flex-direction:column;gap:16px;min-width:0}@media (max-width: 768px){.home-grid{grid-template-columns:1fr}}.chat-sidebar{width:320px;max-width:320px;flex:0 0 320px;flex-shrink:0;background:var(--panel);border:none;border-right:1px solid var(--border);border-radius:0;padding:0;display:flex;flex-direction:column;gap:0;min-height:0;max-height:100%;overflow:hidden}.chat-sidebar-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;border-bottom:1px solid var(--border)}.chat-title{display:flex;gap:10px;align-items:center;min-width:0}.chat-app-icon{width:36px;height:36px;border-radius:10px;background:#0b5cff14;color:var(--primary);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.chat-title-text{min-width:0}.chat-title-strong{display:block;font-weight:600;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-title-row{display:inline-flex;align-items:center;gap:8px}.chat-label{font-size:12px;color:var(--muted);margin:0}.chat-sidebar-header .status-dot{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;position:static;border:none}.chat-sidebar-header .status-dot.connected{background:#22c55e}.chat-sidebar-header .status-dot.connecting,.chat-sidebar-header .status-dot.disconnected{background:#f59e0b}.chat-banner{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:10px;color:var(--muted);font-size:13px}.chat-banner.error{background:#fff5f5;border-color:#fecdd3;color:#b91c1c}.chat-search{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--panel)}.chat-search-inner{position:relative}.chat-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);opacity:.7}.chat-search input{width:100%;font-size:14px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:10px 12px 10px 36px;outline:none}.chat-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:0;padding-right:0;min-height:0}.chat-list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:0;border:none;border-bottom:1px solid rgba(15,23,42,.06);background:transparent;cursor:pointer;text-align:left}.chat-list-item:hover{background:var(--bg)}.chat-list-item.active{background:#0b5cff14}.chat-list-main{min-width:0;flex:1}.chat-list-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.chat-list-name{font-weight:600;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-meta{font-size:12px;color:var(--muted);opacity:.7;flex-shrink:0}.chat-list-secondary{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-text strong{display:block;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-text small{color:var(--muted);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{background:var(--primary);color:#fff;font-size:12px;font-weight:600;min-width:auto;height:auto;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;margin-left:8px}.avatar-sm,.avatar-md{width:40px;height:40px;border-radius:12px;background:#eef2ff;display:inline-flex;align-items:center;justify-content:center;font-weight:600}.avatar-md{width:48px;height:48px}.avatar-sm img,.avatar-md img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:inherit}.chat-wrapper .avatar-sm{width:36px;height:36px;border-radius:9999px;background:var(--bg);overflow:hidden}.chat-thread{background:var(--panel);border:none;border-radius:0;display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden;width:100%}.chat-thread-header{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.thread-user{display:flex;gap:10px;align-items:center}.thread-user>div:last-child{display:flex;flex-direction:column}.thread-user strong{display:block;font-size:14px;font-weight:600}.thread-user p{margin:0;font-size:12px}.chat-messages{flex:1;padding:16px 24px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;background:var(--bg);min-height:0}.chat-bubble{background:#fff;border:1px solid var(--border);border-radius:16px;padding:10px 12px;max-width:75%}.chat-bubble.mine{margin-left:auto;background:#eef2ff;color:inherit;border-color:#4f46e533}.chat-bubble-header{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted);gap:12px;margin-bottom:4px}.chat-bubble-header span{font-weight:600;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-bubble-header small{flex-shrink:0;opacity:.7}.chat-bubble-content{white-space:pre-wrap}.chat-composer{border-top:1px solid var(--border);padding:16px 24px;display:flex;gap:12px;background:var(--panel);box-shadow:none;flex-shrink:0}.chat-composer textarea{width:100%;min-width:0;flex:1;resize:none;border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:14px;box-sizing:border-box;background:var(--bg);outline:none}.send-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;background:var(--primary);color:#fff;border:none;border-radius:12px;cursor:pointer}.send-btn:disabled{opacity:.6;cursor:not-allowed}.chat-empty{flex:1;display:grid;place-items:center;color:var(--muted);gap:10px}.text-center{text-align:center}.text-sm{font-size:13px}.muted{color:var(--muted)}@media (max-width: 1024px){.chat-wrapper{padding:0}}.clock-in-card{background:var(--panel);border-radius:var(--radius);padding:20px;border:2px solid var(--border);box-shadow:0 12px 30px #0f172a0f;transition:border-color .3s ease,background .3s ease}.clock-in-card.inside{border-color:var(--success);background:linear-gradient(135deg,rgba(15,157,88,.05),transparent)}.clock-in-card.outside{border-color:var(--accent);background:linear-gradient(135deg,rgba(255,179,71,.08),transparent)}.clock-in-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.clock-in-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--primary)}.clock-in-card.inside .clock-in-icon{background:#0f9d5826;color:var(--success)}.clock-in-card.outside .clock-in-icon{background:#ffb34733;color:#e67e00}.clock-in-status{display:flex;align-items:center;gap:8px}.status-label{font-weight:600;color:var(--sidebar-text)}.clock-in-last{display:flex;flex-direction:column;gap:2px;margin-bottom:16px;padding:12px;background:var(--bg);border-radius:12px}.last-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.last-date{font-size:14px;color:var(--sidebar-text);text-transform:capitalize}.last-time{font-size:24px;font-weight:700;color:var(--sidebar-text)}.clock-in-button{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.clock-in-button.enter{background:var(--primary);color:#fff}.clock-in-button.enter:hover{background:var(--primary-strong);transform:translateY(-1px)}.clock-in-button.exit{background:#ea4335;color:#fff}.clock-in-button.exit:hover{background:#d33426;transform:translateY(-1px)}.inbox-card{background:var(--panel);border-radius:var(--radius);padding:18px;border:1px solid var(--border);box-shadow:0 12px 30px #0f172a0f}.inbox-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.inbox-title{display:flex;align-items:center;gap:8px;color:var(--sidebar-text)}.inbox-title h3{margin:0;font-size:16px}.inbox-badge{padding:4px 10px;background:var(--primary);color:#fff;border-radius:12px;font-size:12px;font-weight:600}.inbox-messages{display:flex;flex-direction:column;gap:2px}.inbox-message{display:flex;align-items:flex-start;gap:12px;padding:10px;border-radius:12px;cursor:pointer;transition:background .2s ease}.inbox-message:hover{background:var(--bg)}.inbox-message.unread{background:#4f46e50a}.inbox-message.unread:hover{background:#4f46e514}.message-avatar{position:relative;flex-shrink:0}.message-avatar img,.message-avatar .avatar-placeholder{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.avatar-placeholder{background:linear-gradient(135deg,var(--primary),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.unread-dot{position:absolute;bottom:0;right:0;color:var(--primary)}.message-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.message-header{display:flex;justify-content:space-between;align-items:center}.message-sender{font-weight:600;font-size:14px;color:var(--sidebar-text)}.message-date{font-size:12px;color:var(--muted)}.message-subject{font-size:13px;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-preview{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inbox-view-all{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;margin-top:10px;background:transparent;border:1px solid var(--border);border-radius:12px;color:var(--primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.inbox-view-all:hover{background:var(--bg);border-color:var(--primary)}.comunicados-home-alert{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fef3c7;border:1px solid #fbbf24;border-radius:10px;font-size:13px;color:#92400e;margin-bottom:14px}.comunicados-home-alert svg{flex-shrink:0;color:#d97706}.urgent-label{color:#dc2626;font-weight:600;font-size:11px;text-transform:uppercase}.avatar-placeholder.urgent{background:linear-gradient(135deg,#ef4444,#dc2626)}.comunicado-status{margin-top:4px}.status-confirmed{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#16a34a;font-weight:500}.status-pending{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#d97706;font-weight:500}.company-links-card.single-section{gap:0}.company-links-card{background:var(--panel);border-radius:var(--radius);padding:18px;border:1px solid var(--border);box-shadow:0 12px 30px #0f172a0f;display:flex;flex-direction:column;gap:20px}.links-section .section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--sidebar-text)}.links-section h4{margin:0;font-size:14px;font-weight:600}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.company-link{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg);border-radius:10px;font-size:13px;color:var(--sidebar-text);text-decoration:none;transition:all .2s ease}.company-link:hover{background:var(--primary);color:#fff}.holidays-list,.events-list{display:flex;flex-direction:column;gap:8px}.holiday-item,.event-item{display:flex;align-items:center;gap:12px;padding:8px;background:var(--bg);border-radius:10px}.holiday-date,.event-date{width:44px;height:44px;background:#fff;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--border)}.date-day{font-size:16px;font-weight:700;color:var(--sidebar-text);line-height:1}.date-month{font-size:10px;color:var(--muted);text-transform:uppercase}.holiday-info,.event-info{flex:1;display:flex;flex-direction:column;gap:2px}.holiday-name,.event-title{font-size:13px;font-weight:500;color:var(--sidebar-text)}.holiday-countdown{font-size:11px;color:var(--primary);font-weight:500}.event-location{font-size:11px;color:var(--muted)}.publications-card{background:var(--panel);border-radius:var(--radius);padding:18px;border:1px solid var(--border);box-shadow:0 12px 30px #0f172a0f}.publications-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.publications-header h3{margin:0;font-size:16px;color:var(--sidebar-text)}.create-publication-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--primary);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.create-publication-btn:hover{background:var(--primary-strong);transform:translateY(-1px)}.publications-list{display:flex;flex-direction:column;gap:16px}.publication-item{padding:16px;background:var(--bg);border-radius:14px}.publication-author{display:flex;align-items:center;gap:10px;margin-bottom:12px}.author-avatar img,.author-avatar .avatar-placeholder{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.author-info{flex:1;display:flex;flex-direction:column}.author-name{font-weight:600;font-size:14px;color:var(--sidebar-text)}.author-meta{font-size:12px;color:var(--muted)}.publication-menu{background:transparent;border:none;padding:6px;cursor:pointer;color:var(--muted);border-radius:8px;transition:background .2s ease}.publication-menu:hover{background:var(--panel)}.publication-content p{margin:0 0 12px;font-size:14px;line-height:1.5;color:var(--sidebar-text)}.publication-image{width:100%;max-height:300px;-o-object-fit:cover;object-fit:cover;border-radius:10px;margin-bottom:12px}.publication-actions{display:flex;align-items:center;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:transparent;border:none;border-radius:10px;font-size:13px;color:var(--muted);cursor:pointer;transition:all .2s ease}.action-btn:hover{background:var(--panel);color:var(--sidebar-text)}.action-btn.liked{color:#ea4335}.connect-btn{margin-left:auto;padding:8px 16px;background:transparent;border:1px solid var(--primary);border-radius:10px;color:var(--primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.connect-btn:hover{background:var(--primary);color:#fff}.team-card{background:var(--panel);border-radius:var(--radius);padding:18px;border:1px solid var(--border);box-shadow:0 12px 30px #0f172a0f}.team-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.team-title{display:flex;align-items:center;gap:8px;color:var(--sidebar-text)}.team-title h3{margin:0;font-size:16px}.present-count{font-size:13px;color:var(--success);font-weight:500}.team-list{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto}.team-member{display:flex;align-items:center;gap:12px;padding:10px;border-radius:12px;cursor:pointer;transition:background .2s ease;border:2px solid transparent}.team-member:hover{background:var(--bg)}.team-member.selected{background:#4f46e514;border-color:var(--primary)}.member-avatar{position:relative;flex-shrink:0}.member-avatar img,.member-avatar .avatar-placeholder{width:38px;height:38px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.member-avatar .status-dot{position:absolute;bottom:0;right:0;border:2px solid var(--panel);border-radius:50%}.member-info{flex:1;display:flex;flex-direction:column}.member-name{font-weight:500;font-size:14px;color:var(--sidebar-text)}.member-status{font-size:12px;color:var(--muted)}.member-message-btn{padding:8px;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--muted);cursor:pointer;transition:all .2s ease}.member-message-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}.team-actions{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.team-action-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.team-action-btn.primary{background:var(--primary);color:#fff}.team-action-btn.primary:hover{background:var(--primary-strong);transform:translateY(-1px)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-background{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#f9fafb,#eef2ff);z-index:0}.login-gradient-1{position:absolute;top:-20%;left:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(255,209,170,.5) 0%,transparent 70%);animation:float 20s ease-in-out infinite}.login-gradient-2{position:absolute;bottom:-20%;right:-10%;width:70%;height:70%;background:radial-gradient(circle,rgba(165,180,252,.5) 0%,transparent 70%);animation:float 25s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.login-container{position:relative;z-index:1;width:100%;max-width:420px;padding:20px}.login-card{background:#ffffffd9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:40px 36px;box-shadow:0 4px 24px #0000000a,0 12px 48px #4f46e514;border:1px solid rgba(255,255,255,.8)}.login-header{text-align:center;margin-bottom:32px}.login-logo{display:inline-flex;margin-bottom:16px}.login-logo img{height:56px;width:auto;-o-object-fit:contain;object-fit:contain}.login-logo-placeholder{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--primary),#6366f1);display:flex;align-items:center;justify-content:center;color:#fff}.login-company{font-size:22px;font-weight:700;color:var(--sidebar-text);margin:0 0 4px}.login-subtitle{font-size:14px;color:var(--muted);margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-welcome{text-align:center;margin-bottom:8px}.login-welcome h2{font-size:20px;font-weight:600;color:var(--sidebar-text);margin:0 0 4px}.login-welcome p{font-size:14px;color:var(--muted);margin:0}.login-error{padding:12px 16px;background:#ea433514;border:1px solid rgba(234,67,53,.2);border-radius:12px;color:#c62828;font-size:14px;text-align:center}.login-field{display:flex;flex-direction:column;gap:8px}.login-field label{font-size:13px;font-weight:600;color:var(--sidebar-text)}.login-field input{width:100%;padding:14px 16px;border:1px solid var(--border);border-radius:12px;font-size:15px;color:var(--sidebar-text);background:#fff;transition:all .2s ease}.login-field input::-moz-placeholder{color:#a0aec0}.login-field input::placeholder{color:#a0aec0}.login-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.login-field input:disabled{background:var(--bg);cursor:not-allowed}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:48px}.password-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--muted);cursor:pointer;border-radius:10px;transition:all .2s ease}.password-toggle:hover{background:var(--bg);color:var(--sidebar-text)}.login-forgot{align-self:flex-end;background:none;border:none;color:var(--primary);font-size:13px;font-weight:500;cursor:pointer;padding:0;margin-top:-8px}.login-forgot:hover{text-decoration:underline}.login-submit{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;background:var(--primary);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.login-submit:hover:not(:disabled){background:var(--primary-strong);transform:translateY(-1px);box-shadow:0 8px 24px #4f46e540}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}.login-footer p{font-size:12px;color:var(--muted);margin:0}.login-footer strong{color:var(--primary);font-weight:600}@media (max-width: 480px){.login-card{padding:32px 24px;border-radius:20px}.login-company{font-size:20px}}@media (max-width: 960px){.app-shell{grid-template-columns:1fr}.sidebar{position:absolute}.mobile-toggle{display:inline-flex;margin-right:10px}.nav-group{flex:1}}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-700:hover{--tw-bg-opacity: 1;background-color:rgb(67 56 202 / var(--tw-bg-opacity, 1))}.hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.hover\:text-indigo-800:hover{--tw-text-opacity: 1;color:rgb(55 48 163 / var(--tw-text-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-indigo-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(99 102 241 / var(--tw-ring-opacity, 1))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}
