html,body,#root{height:100%}*{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-page: #fafafa;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-hover: #f3f4f6;--bg-active: #e5e7eb;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--text-on-brand: #111827;--border-primary: #e5e7eb;--border-secondary: #d1d5db;--border-focus: #f59e0b;--brand: #ffcc00;--brand-hover: #ffd633;--brand-active: #e0b700;--brand-border: #d4af00;--primary: #f59e0b;--primary-hover: #d97706;--primary-active: #b45309;--success: #10b981;--error: #ef4444;--warning: #f59e0b;--info: #3b82f6;--selected-bg: #fff3cd;--selected-text: #111827;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--ring: 0 0 0 3px rgba(245, 158, 11, .3);--radius: 10px;--transition: .2s ease;--divider: #e5e7eb}[data-theme=dark]{--bg-page: #0f172a;--bg-primary: #1e293b;--bg-secondary: #334155;--bg-hover: #475569;--bg-active: #64748b;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-on-brand: #0f172a;--border-primary: #334155;--border-secondary: #475569;--border-focus: #fbbf24;--brand: #fbbf24;--brand-hover: #fcd34d;--brand-active: #f59e0b;--brand-border: #d97706;--primary: #fbbf24;--primary-hover: #fcd34d;--primary-active: #fde68a;--success: #34d399;--error: #f87171;--warning: #fbbf24;--info: #60a5fa;--selected-bg: #854d0e;--selected-text: #fef3c7;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--ring: 0 0 0 3px rgba(251, 191, 36, .3);--divider: #475569}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-page);color:var(--text-primary);transition:background-color .2s ease,color .2s ease}#root{width:100%;height:100vh;margin:0;overflow:hidden}.under-construction{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.module-title{font-size:3rem;font-weight:700;margin-bottom:1rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.status-badge{display:inline-block;padding:.5rem 1.5rem;background:#f59e0b;color:#1f2937;border-radius:2rem;font-weight:600;margin-bottom:2rem;animation:pulse 2s ease-in-out infinite}.description{font-size:1.2rem;color:#9ca3af;max-width:600px;margin:0 auto 2rem;line-height:1.6}.features{text-align:left;max-width:500px;margin:2rem auto;padding:2rem;background:#ffffff0d;border-radius:1rem;border:1px solid rgba(255,255,255,.1)}.features h2{font-size:1.5rem;margin-bottom:1rem;color:#f3f4f6}.features ul{list-style:none;padding:0}.features li{padding:.5rem 0;color:#d1d5db;display:flex;align-items:center}.features li:before{content:"🚧";margin-right:.75rem;font-size:1.2rem}.back-link{margin-top:2rem;display:inline-block;padding:.75rem 2rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;text-decoration:none;border-radius:.5rem;font-weight:600;transition:transform .2s}.back-link:hover{transform:translateY(-2px)}.btn{padding:8px 16px;border:1px solid var(--border-primary);border-radius:var(--radius);background:var(--bg-primary);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all var(--transition)}.btn:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.btn:active{background:var(--bg-active)}.icon-btn{padding:6px;line-height:0;border:1px solid transparent;border-radius:8px;background:transparent;cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.input{padding:8px 12px;border:1px solid var(--border-primary);border-radius:var(--radius);background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:all var(--transition)}.input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--ring)}.input:disabled{opacity:.5;cursor:not-allowed}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--brand);border-bottom:1px solid var(--brand-border);color:var(--text-on-brand)}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:8px 6px;border-bottom:1px solid var(--border-primary);color:var(--text-primary)}.table th{font-weight:600;color:var(--text-secondary)}.table tbody tr{transition:background-color var(--transition)}.table tbody tr:hover{background:var(--bg-hover)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.msg-media-audio{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.25rem}.msg-media-audio audio{width:100%;max-width:280px;height:40px;border-radius:1rem}.msg-media-filename{font-size:.7rem;color:var(--text-secondary, #6b7280);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.msg-media-placeholder{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:1rem;background-color:var(--bg-secondary, #f3f4f6);font-size:.8125rem;color:var(--text-secondary, #6b7280);max-width:280px;margin-bottom:.25rem}.msg-media-placeholder--error{color:#ef4444;background-color:#fef2f2}[data-theme=dark] .msg-media-placeholder--error{color:#fca5a5;background-color:#ef44441a}.voice-recorder-preview{display:flex;align-items:center;gap:.5rem;background:var(--bg-tertiary, #f0f0f0);border-radius:24px;padding:.375rem .5rem;animation:voice-fade-in .2s ease;flex:1;min-width:0}.voice-recorder-audio{flex:1;min-width:0;max-width:220px;height:36px;border-radius:1rem}.voice-recorder-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:50%;background:transparent;cursor:pointer;flex-shrink:0;transition:all .15s}.voice-recorder-btn--discard{color:#ef4444}.voice-recorder-btn--discard:hover{background:#ef44441a}.voice-recorder-btn--send{background:#25d366;color:#fff}.voice-recorder-btn--send:hover{background:#1da851;transform:scale(1.05)}.voice-recorder-btn--stop{background:#ef4444;color:#fff}.voice-recorder-btn--stop:hover{background:#dc2626;transform:scale(1.05)}.voice-recorder-recording{display:flex;align-items:center;gap:.5rem;background:var(--bg-tertiary, #f0f0f0);border-radius:24px;padding:.375rem .75rem;animation:voice-fade-in .2s ease;flex:1;min-width:0}.voice-recorder-pulse{width:8px;height:8px;border-radius:50%;background:#ef4444;flex-shrink:0;animation:voice-pulse 1s ease-in-out infinite}.voice-recorder-timer{font-size:.875rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-primary, #111827);min-width:2.5rem;flex-shrink:0}.msg-input-btn--mic{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:50%;background:transparent;color:var(--text-secondary, #6b7280);cursor:pointer;flex-shrink:0;transition:color .15s}.msg-input-btn--mic:hover:not(:disabled){color:#25d366}.msg-input-btn--mic:disabled{opacity:.4;cursor:not-allowed}@keyframes voice-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes voice-pulse{0%,to{opacity:1}50%{opacity:.3}}[data-theme=dark] .msg-media-audio audio{color-scheme:dark}[data-theme=dark] .msg-media-placeholder{background-color:var(--bg-secondary, #1e293b)}[data-theme=dark] .voice-recorder-preview,[data-theme=dark] .voice-recorder-recording{background:var(--bg-tertiary, #1e293b)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-primary, #ffffff);border-radius:.75rem;width:90%;max-width:440px;max-height:90vh;box-shadow:0 20px 60px #0003;animation:modalSlideIn .2s ease;overflow:hidden;display:flex;flex-direction:column}@keyframes modalSlideIn{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border, #e5e7eb)}.modal-header h2,.modal-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary, #111827)}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border, #e5e7eb);border-radius:.375rem;background:transparent;color:var(--text-secondary, #6b7280);font-size:1.5rem;line-height:1;cursor:pointer;transition:all .15s}.modal-close:hover{background:var(--bg-hover, #f3f4f6);color:var(--text-primary, #111827);border-color:var(--border, #d1d5db)}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.625rem;flex:1;overflow-y:auto;min-height:0}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid var(--border, #e5e7eb)}.modal-btn{padding:.5rem 1rem;border-radius:.375rem;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal-btn--secondary{border:1px solid var(--border, #e5e7eb);background:transparent;color:var(--text-primary, #111827)}.modal-btn--secondary:hover:not(:disabled){background:var(--bg-hover, #f3f4f6);border-color:var(--border, #d1d5db)}.modal-btn--primary{border:1px solid #25d366;background:#25d366;color:#fff}.modal-btn--primary:hover:not(:disabled){background:#1da851;border-color:#1da851}.template-modal-name{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg-hover, #f3f4f6);border-radius:.5rem;margin-bottom:1rem}.template-modal-name strong{font-size:1rem;color:var(--text-primary, #111827)}.template-modal-category{font-size:.75rem;color:var(--text-secondary, #6b7280);text-transform:uppercase;padding:.25rem .5rem;background:var(--bg-page, #fafafa);border-radius:.25rem}.template-modal-preview{margin-bottom:1rem}.template-modal-preview>label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-primary, #111827);margin-bottom:.5rem}.template-modal-preview-text{padding:.75rem;background:var(--bg-page, #fafafa);border:1px solid var(--border, #e5e7eb);border-radius:.5rem;font-size:.875rem;line-height:1.5;color:var(--text-secondary, #6b7280);white-space:pre-wrap;min-height:80px}.template-modal-variables{display:flex;flex-direction:column;gap:.75rem}.template-modal-variables>label{font-size:.8125rem;font-weight:500;color:var(--text-primary, #111827)}.template-modal-var-row{display:flex;align-items:center;gap:.75rem}.template-modal-var-label{flex-shrink:0;min-width:52px;font-size:.8125rem;font-weight:600;color:var(--primary, #f59e0b);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:var(--bg-page, #fafafa);padding:.25rem .5rem;border-radius:.25rem;text-align:center}.template-modal-var-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border, #e5e7eb);border-radius:.375rem;background:var(--bg-page, #fafafa);color:var(--text-primary, #111827);font-size:.875rem;font-family:inherit;transition:border-color .15s}.template-modal-var-input:focus{outline:none;border-color:var(--primary, #f59e0b);box-shadow:0 0 0 3px #f59e0b1a}.template-modal-var-input:disabled{opacity:.5;cursor:not-allowed}.template-modal-var-input::placeholder{color:var(--text-secondary, #9ca3af)}.template-modal-hint{font-size:.75rem;color:var(--text-secondary, #6b7280);padding:.5rem;background:#3b82f61a;border-left:3px solid #3b82f6;border-radius:.25rem;margin-bottom:.5rem}.template-modal-no-vars{padding:1rem;text-align:center;color:var(--text-secondary, #6b7280);font-size:.875rem;background:var(--bg-page, #fafafa);border-radius:.5rem}.modal-loading{text-align:center;color:var(--text-secondary, #6b7280);font-size:.875rem;padding:.75rem}[data-theme=dark] .modal-content{background:var(--bg-primary, #1f2937)}[data-theme=dark] .template-modal-name{background:#ffffff0d}[data-theme=dark] .template-modal-name strong{color:#f9fafb}[data-theme=dark] .template-modal-category{background:#ffffff1a;color:#9ca3af}[data-theme=dark] .template-modal-preview-text{background:#ffffff0d;border-color:#ffffff1a;color:#9ca3af}[data-theme=dark] .template-modal-var-label{background:#ffffff14;color:var(--primary, #f59e0b)}[data-theme=dark] .template-modal-var-input{background:#ffffff0d;border-color:#ffffff1a;color:#f9fafb}[data-theme=dark] .template-modal-var-input:focus{border-color:var(--primary, #f59e0b);box-shadow:0 0 0 3px #f59e0b26}[data-theme=dark] .template-modal-hint{background:#3b82f626;border-color:#3b82f6}[data-theme=dark] .template-modal-no-vars{background:#ffffff0d;color:#9ca3af}[data-theme=dark] .modal-btn--secondary{border-color:#ffffff26;color:#e5e7eb}[data-theme=dark] .modal-btn--secondary:hover:not(:disabled){background:#ffffff0d}[data-theme=dark] .modal-close{border-color:#ffffff1a;color:#9ca3af}[data-theme=dark] .modal-close:hover{background:#ffffff0d;color:#f9fafb}.directory-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.directory-content{display:flex;flex:1;overflow:hidden}.directory-nav{width:250px;background:var(--bg-page);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow-y:auto}.nav-header{padding:1.5rem 1rem;border-bottom:1px solid var(--border-primary)}.nav-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.nav-list{list-style:none;margin:0;padding:.5rem 0}.nav-list li{margin:0;padding:0}.nav-item{width:100%;padding:.75rem 1rem;border:none;background:transparent;text-align:left;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;border-left:3px solid transparent}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--selected-bg);color:var(--success);border-left-color:var(--success);font-weight:600}.directory-main{flex:1;display:flex;overflow:hidden;background:var(--bg-page)}.add-company-modal{max-width:700px;width:90%;max-height:85vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border-primary);margin-bottom:1rem}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.btn-close{background:transparent;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:.25rem;line-height:1;transition:all var(--transition);border-radius:4px}.btn-close:hover{background:var(--bg-hover);color:var(--text-primary)}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.tab{padding:.75rem 1.5rem;background:var(--bg-secondary);border:1px solid var(--border-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap;border-radius:8px}.tab:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.tab.active{background:var(--primary);color:#000;border-color:var(--primary);font-weight:600;box-shadow:0 2px 4px #f59e0b4d}.tab-content{display:flex;flex-direction:column;gap:1.5rem}.tab-description{color:var(--text-secondary);font-size:.875rem;margin:0;padding:.75rem 1rem;background:var(--bg-secondary);border-left:3px solid var(--primary);border-radius:4px}.search-section{display:flex;flex-direction:column;gap:.5rem}.search-section label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.search-input{padding:.75rem 1rem;border:1px solid var(--border-primary);border-radius:8px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition)}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.loading,.empty-results{text-align:center;padding:2rem;color:var(--text-secondary)}.empty-results p{margin:.5rem 0}.hint{font-size:.875rem}.link-button{background:none;border:none;color:var(--primary);text-decoration:underline;cursor:pointer;font-size:inherit;padding:0}.link-button:hover{color:var(--primary-hover)}.search-results{display:flex;flex-direction:column;gap:1rem}.results-count{font-size:.875rem;color:var(--text-secondary);margin:0;font-weight:500}.add-company-modal .companies-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem;background:var(--bg-secondary);border-radius:8px}.company-card{padding:.75rem 1rem;border:1px solid var(--border-primary);border-radius:8px;background:var(--bg-primary);cursor:pointer;transition:all var(--transition)}.company-card:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.company-card.selected{background:var(--selected-bg);border-color:var(--primary);box-shadow:0 0 0 2px #f59e0b1a}.company-card .company-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.company-card .company-commercial{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.company-card .company-rfc{font-size:.75rem;color:var(--text-tertiary);font-family:monospace;margin-bottom:.25rem}.company-card .company-giro{font-size:.75rem;color:var(--text-tertiary);font-style:italic}.assignment-section,.form-section{padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-primary)}.assignment-section h3,.form-section h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.section-hint{font-size:.75rem;color:var(--text-secondary);margin:0 0 1rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-field{display:flex;flex-direction:column;gap:.375rem}.form-field.full-width{grid-column:1 / -1}.form-field label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.required{color:var(--error)}.form-field input,.form-field textarea{padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:6px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition)}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.form-field textarea{resize:vertical;font-family:inherit}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1.5rem;margin-top:0;border-top:none!important}.modal-actions .btn{padding:.5rem 1.5rem;font-size:.875rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all var(--transition)}.modal-actions .btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-primary)}.modal-actions .btn-secondary:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.modal-actions .btn-primary{background:var(--primary);color:#000;border:none}.modal-actions .btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.modal-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.companies-list::-webkit-scrollbar{width:8px}.companies-list::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.companies-list::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.companies-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:640px){.add-company-modal{width:95%;max-height:90vh}.form-grid{grid-template-columns:1fr}.tabs{overflow-x:auto}.tab{padding:.5rem 1rem;font-size:.8rem}}.add-contact-modal{max-width:800px}.add-contact-modal .contacts-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem;background:var(--bg-secondary);border-radius:8px}.contact-card{padding:.75rem 1rem;border:1px solid var(--border-primary);border-radius:8px;background:var(--bg-primary);cursor:pointer;transition:all var(--transition)}.contact-card:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.contact-card.selected{background:var(--selected-bg);border-color:var(--primary);box-shadow:0 0 0 2px #f59e0b1a}.contact-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.contact-card-name{font-weight:600;font-size:.875rem;color:var(--text-primary)}.contact-card-type{font-size:.75rem;color:var(--text-secondary);opacity:.8}.contact-card.selected .contact-card-type{color:var(--text-primary);opacity:1}.contact-card-details{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem}.contact-card-email{font-weight:500;color:var(--text-primary)}.contact-card-position{font-style:italic;color:var(--text-secondary);opacity:.9}.contact-card-phone{color:var(--text-secondary);opacity:.8}.contact-card.selected .contact-card-email,.contact-card.selected .contact-card-position,.contact-card.selected .contact-card-phone{opacity:1}.project-fields{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-primary)}.project-fields h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.excel-import-modal{width:90%;max-width:900px;max-height:90vh;overflow-y:auto}.import-step-upload{padding:20px 0}.import-instructions{background-color:#f8f9fa;border-left:4px solid #007bff;padding:15px;margin-bottom:30px;border-radius:4px}.import-instructions h3{margin-top:0;margin-bottom:10px;color:#007bff}.import-instructions ol{margin:0;padding-left:20px}.import-instructions li{margin-bottom:8px}.import-actions{display:flex;flex-direction:column;gap:15px;align-items:stretch}.file-upload-area{display:flex;align-items:center;gap:10px;padding:15px;border:2px dashed #dee2e6;border-radius:8px;background-color:#f8f9fa}.file-name{color:#28a745;font-weight:500}.import-step-preview{padding:20px 0}.preview-summary{margin-bottom:25px}.preview-summary h3{margin-bottom:15px}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin-bottom:20px}.stat{display:flex;flex-direction:column;padding:15px;background-color:#f8f9fa;border-radius:8px;border-left:4px solid #6c757d}.stat-label{font-size:.875rem;color:#6c757d;margin-bottom:5px}.stat-value{font-size:1.5rem;font-weight:700;color:#212529}.stat-create{border-left-color:#28a745}.stat-create .stat-value{color:#28a745}.stat-update{border-left-color:#007bff}.stat-update .stat-value{color:#007bff}.stat-affiliate{border-left-color:#17a2b8}.stat-affiliate .stat-value{color:#17a2b8}.stat-warning{border-left-color:#ffc107}.stat-warning .stat-value{color:#ffc107}.stat-error{border-left-color:#dc3545}.stat-error .stat-value{color:#dc3545}.preview-rows-container{margin-bottom:25px}.preview-rows-container h4{margin-bottom:15px}.preview-rows{max-height:400px;overflow-y:auto;border:1px solid #dee2e6;border-radius:8px}.preview-row{padding:15px;border-bottom:1px solid #dee2e6;background-color:#fff}.preview-row:last-child{border-bottom:none}.preview-row.row-error{background-color:#fff5f5;border-left:4px solid #dc3545}.preview-row.row-warning{background-color:#fffbf0;border-left:4px solid #ffc107}.row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.row-number{font-weight:600;color:#495057}.row-action{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.action-create{background-color:#d4edda;color:#155724}.action-update{background-color:#d1ecf1;color:#0c5460}.action-affiliate{background-color:#d6eaf8;color:#004085}.row-errors,.row-warnings{margin-top:10px}.error-message{color:#dc3545;font-size:.875rem;margin-bottom:5px}.warning-message{color:#856404;font-size:.875rem;margin-bottom:5px}.import-mode-selector{margin-bottom:25px;padding:20px;background-color:#f8f9fa;border-radius:8px}.import-mode-selector h4{margin-bottom:15px}.mode-options{display:flex;flex-direction:column;gap:10px}.mode-options label{display:flex;align-items:center;gap:10px;cursor:pointer;padding:10px;border-radius:4px;transition:background-color .2s}.mode-options label:hover{background-color:#e9ecef}.mode-options input[type=radio]{width:18px;height:18px;cursor:pointer}.preview-actions,.result-actions{display:flex;justify-content:space-between;gap:15px;padding-top:20px;border-top:1px solid #dee2e6}.import-step-result{padding:20px 0}.result-summary h3{margin-bottom:20px;font-size:1.5rem}.result-errors{margin-top:25px;padding:20px;background-color:#fff5f5;border-radius:8px;border-left:4px solid #dc3545}.result-errors h4{margin-bottom:15px;color:#dc3545}.error-item{padding:8px 0;color:#721c24;font-size:.875rem}.alert{padding:15px;margin-bottom:20px;border-radius:4px;border-left:4px solid}.alert-error{background-color:#fff5f5;border-left-color:#dc3545;color:#721c24}.alert-warning{background-color:#fffbf0;border-left-color:#ffc107;color:#856404}.alert strong{display:block;margin-bottom:8px}.alert ul{margin:0;padding-left:20px}.alert li{margin-bottom:4px}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-outline{background-color:#fff;color:#007bff;border:2px solid #007bff}.btn-outline:hover:not(:disabled){background-color:#007bff;color:#fff}@media(prefers-color-scheme:dark){.excel-import-modal{background-color:#1e1e1e;color:#e0e0e0}.import-instructions{background-color:#2d2d2d;border-left-color:#4a9eff;color:#e0e0e0}.import-instructions h3{color:#4a9eff}.file-upload-area{background-color:#2d2d2d;border-color:#444}.file-name{color:#4ade80}.stat{background-color:#2d2d2d;color:#e0e0e0}.stat-label{color:#a0a0a0}.stat-value{color:#e0e0e0}.stat-create .stat-value{color:#4ade80}.stat-update .stat-value{color:#4a9eff}.stat-affiliate .stat-value{color:#22d3ee}.stat-warning .stat-value{color:#fbbf24}.stat-error .stat-value{color:#f87171}.preview-rows{border-color:#444;background-color:#1e1e1e}.preview-row{background-color:#2d2d2d;border-bottom-color:#444;color:#e0e0e0}.preview-row.row-error{background-color:#3d1f1f;border-left-color:#f87171}.preview-row.row-warning{background-color:#3d3520;border-left-color:#fbbf24}.row-number{color:#b0b0b0}.action-create{background-color:#1e4620;color:#4ade80}.action-update{background-color:#1e3a5f;color:#4a9eff}.action-affiliate{background-color:#1a3d4f;color:#22d3ee}.error-message{color:#f87171}.warning-message{color:#fbbf24}.import-mode-selector{background-color:#2d2d2d;color:#e0e0e0}.mode-options label{color:#e0e0e0}.mode-options label:hover{background-color:#3d3d3d}.preview-actions,.result-actions{border-top-color:#444}.result-errors{background-color:#3d1f1f;border-left-color:#f87171}.result-errors h4,.error-item{color:#f87171}.alert-error{background-color:#3d1f1f;border-left-color:#f87171;color:#f87171}.alert-warning{background-color:#3d3520;border-left-color:#fbbf24;color:#fbbf24}.btn-primary{background-color:#4a9eff;color:#1e1e1e}.btn-primary:hover:not(:disabled){background-color:#357abd}.btn-secondary{background-color:#555;color:#e0e0e0}.btn-secondary:hover:not(:disabled){background-color:#666}.btn-outline{background-color:transparent;color:#4a9eff;border-color:#4a9eff}.btn-outline:hover:not(:disabled){background-color:#4a9eff;color:#1e1e1e}}.companies-page{display:grid;grid-template-columns:40% 60%;gap:1rem;padding:1.5rem;height:100%;width:100%;max-width:none;box-sizing:border-box}.companies-empty{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.125rem}.companies-list-panel,.company-details-panel{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;min-height:0}.panel-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.header-actions{display:flex;gap:.5rem;align-items:center}.btn-add{padding:.5rem 1rem;background:var(--primary);color:#000;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.btn-add:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-export,.btn-import{padding:.5rem 1rem;border:1px solid var(--border-secondary);background:var(--bg-primary);color:var(--text-primary);border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;gap:.375rem}.btn-export:hover{background:#e0f2fe;border-color:#0284c7;color:#0284c7;transform:translateY(-1px)}.btn-import:hover{background:#fef3c7;border-color:#f59e0b;color:#f59e0b;transform:translateY(-1px)}.companies-list{flex:1 1 auto;overflow-y:auto;padding:.5rem;min-height:0}.company-item{display:flex;flex-direction:column;padding:.75rem 1rem;margin-bottom:.5rem;border:1px solid var(--border-primary);border-radius:8px;cursor:pointer;transition:all var(--transition);background:var(--bg-primary)}.company-item:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.company-item.selected{background:var(--selected-bg);border-color:var(--primary);box-shadow:0 0 0 2px #f59e0b1a}.company-name{font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-commercial{font-size:.875rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:.25rem}.company-role{font-size:.75rem;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:.25rem;font-style:italic}.no-selection{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem;text-align:center;color:var(--text-secondary)}.details-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.details-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;gap:.5rem}.btn-edit,.btn-save,.btn-cancel,.btn-remove,.btn-delete{padding:.5rem .875rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.btn-edit{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-edit:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.btn-save{background:var(--success);color:#fff}.btn-save:hover{background:var(--success-hover)}.btn-cancel{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-cancel:hover{background:var(--bg-secondary)}.btn-remove{background:#f59e0b1a;color:var(--primary);border:1px solid rgba(245,158,11,.3)}.btn-remove:hover{background:#f59e0b33;border-color:var(--primary)}.btn-delete{background:transparent;color:var(--error);border:1px solid transparent}.btn-delete:hover{background:#ef44441a;border-color:#ef44444d}.btn-primary{background:var(--primary);color:#000;border:none;padding:.5rem 1rem;font-size:.875rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all var(--transition)}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-primary);padding:.5rem 1rem;font-size:.875rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all var(--transition)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.details-content{flex:1;overflow-y:auto;padding:1.25rem}.detail-section{margin-bottom:2rem}.detail-section:last-child{margin-bottom:0}.detail-section h3{margin:0 0 1rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.field{display:flex;flex-direction:column;gap:.375rem}.field.full-width{grid-column:1 / -1}.field label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.field .value{font-size:.875rem;color:var(--text-primary);padding:.5rem 0}.field .value a{color:var(--primary);text-decoration:none}.field .value a:hover{text-decoration:underline}.field input,.field textarea{padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:6px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition)}.field input:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f59e0b1a}.field input:disabled{background:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed;opacity:.7}.field textarea{resize:vertical;font-family:inherit}.status{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status.activo{background:var(--success-light);color:var(--success)}.status.inactivo{background:var(--error-light);color:var(--error)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h2{margin:0 0 1rem;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.modal-content p{color:var(--text-secondary);margin-bottom:1.5rem}.modal-content button{padding:.5rem 1rem;background:var(--primary);color:var(--bg-primary);border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.modal-content button:hover{background:var(--primary-hover)}.addresses-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.8rem}.addresses-table th{text-align:left;padding:.5rem;border-bottom:2px solid var(--border-primary);color:var(--text-secondary);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.addresses-table td{padding:.5rem;border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-size:.8rem}.addresses-table tbody tr:hover{background:var(--bg-tertiary)}.tipo-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.tipo-badge.tipo-fiscal{background:var(--primary);color:#000}.tipo-badge.tipo-oficina{background:#22c55e33;color:#22c55e}.tipo-badge.tipo-obra{background:#3b82f633;color:#3b82f6}.tipo-badge.tipo-otra{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-icon{padding:.25rem .5rem;background:transparent;border:none;cursor:pointer;font-size:1rem;transition:all var(--transition);border-radius:4px}.btn-icon:hover:not(:disabled){background:var(--bg-tertiary)}.btn-icon.btn-danger:hover:not(:disabled){background:#ef44441a}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.action-buttons{display:flex;gap:.25rem;justify-content:flex-end}.add-address-form{margin-top:1rem;padding:1.5rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px}.add-address-form h4{margin:0 0 1rem;color:var(--text-primary);font-size:1rem}.add-address-form .form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.add-address-form .field{display:flex;flex-direction:column;gap:.25rem}.add-address-form label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.add-address-form input,.add-address-form select,.add-address-form textarea{padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.875rem}.add-address-form input:focus,.add-address-form select:focus,.add-address-form textarea:focus{outline:none;border-color:var(--primary)}.form-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.section-header-with-action{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header-with-action h3{margin:0;display:flex;align-items:center;gap:.5rem}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .5rem;background:var(--primary);color:#000;border-radius:12px;font-size:.75rem;font-weight:600}.empty-state{padding:2rem;text-align:center;color:var(--text-secondary);font-style:italic;background:var(--bg-tertiary);border-radius:8px;margin-top:1rem}@media(max-width:768px){.companies-page{grid-template-columns:1fr;padding:1rem}.add-address-form .form-grid{grid-template-columns:1fr}.addresses-table{font-size:.875rem}.addresses-table th,.addresses-table td,.affiliations-table th,.affiliations-table td{padding:.5rem .25rem}}.affiliations-table th{text-align:left;padding:.75rem .5rem;background:var(--bg-tertiary);border-bottom:2px solid var(--border-primary);color:var(--text-secondary);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.affiliations-table .status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;display:inline}.affiliations-table .status-badge.actual{background:#22c55e33;color:#22c55e}.affiliations-table .status-badge.pasado{background:var(--bg-tertiary);color:var(--text-secondary)}.search-box{padding:.75rem 1rem;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);flex-shrink:0}.detail-grid-compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem}.detail-grid-compact .field label{font-size:.7rem}.detail-grid-compact .field .value{font-size:.85rem}.contacts-page{display:grid;grid-template-columns:40% 60%;gap:1rem;padding:1.5rem;height:100%;width:100%;max-width:none;box-sizing:border-box}.contacts-empty{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.125rem}.contacts-list-panel,.contact-details-panel{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;min-height:0}.contacts-list{flex:1 1 auto;overflow-y:auto;padding:.5rem;min-height:0}.contact-item{padding:.875rem 1rem;margin-bottom:.5rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:all var(--transition)}.contact-item:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.contact-item.selected{background:var(--selected-bg);border-color:var(--primary);box-shadow:0 0 0 2px #f59e0b1a}.contact-name{font-weight:600;font-size:.9375rem;margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.user-linked-badge{font-size:.875rem;opacity:.7}.contact-details{display:flex;flex-direction:column;gap:.125rem}.contact-email{font-size:.75rem;opacity:.8}.contact-role{font-size:.75rem;font-style:italic;opacity:.7}.affiliations-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.8rem}.affiliations-table th{text-align:left;padding:.5rem;border-bottom:2px solid var(--border-primary);color:var(--text-secondary);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.affiliations-table td{padding:.75rem .5rem;border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-size:.8rem;vertical-align:middle}.affiliations-table tbody tr:hover{background:var(--bg-tertiary)}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.actual{background:#22c55e33;color:#22c55e}.status-badge.pasado{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-link{background:transparent;border:none;color:var(--primary);cursor:pointer;font-size:.875rem;padding:.25rem .5rem;text-decoration:none;transition:all .2s}.btn-link:hover{color:var(--primary-hover, #fbbf24);text-decoration:underline}.add-affiliation-form{margin-top:1rem;padding:1.5rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px}.add-affiliation-form h4{margin:0 0 1rem;color:var(--text-primary);font-size:1rem}.add-affiliation-form .form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.add-affiliation-form .field{display:flex;flex-direction:column;gap:.25rem}.add-affiliation-form .field.full-width{grid-column:1 / -1}.add-affiliation-form label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.add-affiliation-form input[type=text],.add-affiliation-form select,.add-affiliation-form textarea{padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.875rem}.add-affiliation-form input[type=text]:focus,.add-affiliation-form select:focus,.add-affiliation-form textarea:focus{outline:none;border-color:var(--primary)}.add-affiliation-form input[type=checkbox]{width:auto;margin-right:.5rem}@media(max-width:768px){.contacts-page{grid-template-columns:1fr;padding:1rem}.add-affiliation-form .form-grid{grid-template-columns:1fr}.affiliations-table{font-size:.875rem}.affiliations-table th,.affiliations-table td{padding:.5rem .25rem}}.search-box{padding:.75rem 1rem;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.search-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:all .2s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #f59e0b1a}.search-input::placeholder{color:var(--text-secondary);opacity:.7}.link-user-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;margin:1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;border-radius:8px;box-shadow:0 2px 4px #fbbf241a}[data-theme=dark] .link-user-banner{background:linear-gradient(135deg,#78350f,#92400e);border-color:#d97706}.link-user-banner.checking{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#60a5fa;justify-content:center}[data-theme=dark] .link-user-banner.checking{background:linear-gradient(135deg,#1e3a8a,#1e40af);border-color:#3b82f6}.banner-content{display:flex;align-items:center;gap:.75rem;flex:1}.banner-icon{font-size:1.5rem}.banner-text{display:flex;flex-direction:column;gap:.25rem}.banner-text strong{font-weight:600;color:var(--text-primary)}.banner-text span{font-size:.875rem;color:var(--text-secondary)}.btn-link-user{padding:.5rem 1rem;background:#f59e0b;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-link-user:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.btn-link-user:active{transform:translateY(0)}.roles-page{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem;height:100%}.roles-empty{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.125rem}.roles-panel,.role-details-panel,.role-members-panel{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden}.panel-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.panel-subtitle{margin-top:.25rem;font-size:.875rem;color:var(--text-secondary);font-weight:400}.create-form{padding:1rem;display:flex;gap:.5rem;border-bottom:1px solid var(--border-primary)}.create-form .input{flex:1;min-width:0}.create-form .btn{white-space:nowrap}.roles-list{flex:1;overflow-y:auto;padding:.5rem}.role-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;margin-bottom:.5rem;border:1px solid var(--border-primary);border-radius:8px;cursor:pointer;transition:all var(--transition);background:var(--bg-primary)}.role-item:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.role-item.selected{background:var(--selected-bg);border-color:var(--primary);box-shadow:0 0 0 2px #f59e0b1a}.role-info{flex:1;min-width:0}.role-name{font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-icon{padding:.375rem;background:transparent;border:none;cursor:pointer;border-radius:4px;font-size:1rem;line-height:1;transition:all var(--transition);opacity:.6}.btn-icon:hover{opacity:1;background:var(--bg-hover)}.btn-icon.btn-danger:hover{background:#ef44441a}.role-meta{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.meta-item{display:flex;align-items:center;gap:.5rem}.meta-label{font-weight:500;color:var(--text-secondary);min-width:80px}.meta-value{color:var(--text-primary)}.assign-form .input{flex:1;min-width:0}.members-list{flex:1;overflow-y:auto;padding:.5rem}.member-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;margin-bottom:.5rem;border:1px solid var(--border-primary);border-radius:8px;background:var(--bg-primary);transition:all var(--transition)}.member-item:hover{background:var(--bg-hover)}.member-info{flex:1;min-width:0}.member-name{font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-email{font-size:.875rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading,.empty-state{padding:2rem 1rem;text-align:center;color:var(--text-secondary)}.error-message{padding:.75rem 1rem;margin:1rem;background:#ef44441a;border:1px solid var(--error);border-radius:8px;color:var(--error);font-size:.875rem}@media(max-width:768px){.roles-page{grid-template-columns:1fr;padding:1rem}}.dynamic-rule-builder{padding:0;width:100%}.rule-builder-header h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--text-primary)}.rule-builder-header .text-muted{font-size:.875rem;color:var(--text-secondary)}.logic-toggle{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.logic-toggle label{font-weight:500;color:var(--text-primary)}.logic-toggle .btn-group{display:flex;gap:0;border-radius:.375rem;overflow:hidden;border:1px solid var(--border-primary)}.logic-toggle .btn{padding:.5rem 1rem;border:none;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s;font-weight:500}.logic-toggle .btn:first-child{border-right:1px solid var(--border-primary)}.logic-toggle .btn-primary{background:var(--color-primary, #0066cc);color:#fff}.logic-toggle .btn-outline-primary:hover{background:var(--bg-hover, #f0f0f0)}.logic-toggle small{color:var(--text-secondary);font-size:.875rem}.filter-rows{max-height:400px;overflow-y:auto;padding-right:.5rem;margin-bottom:1rem}.filter-rows::-webkit-scrollbar{width:8px}.filter-rows::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.filter-rows::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:4px}.filter-rows::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.filter-row{background-color:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:.5rem;transition:all .2s;margin-bottom:.75rem}.filter-row:hover{border-color:var(--color-primary, #0066cc);box-shadow:0 2px 8px #0000001a}.filter-row .row{padding:.75rem}.filter-row .form-label{font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem;display:block}.filter-row .form-select,.filter-row .form-control{width:100%;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:.375rem;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.filter-row .form-select:focus,.filter-row .form-control:focus{outline:none;border-color:var(--color-primary, #0066cc);box-shadow:0 0 0 2px #0066cc1a}.btn-remove-filter{background:transparent;border:none;color:#dc3545;font-size:1.5rem;line-height:1;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:all .2s}.btn-remove-filter:hover:not(:disabled){background:#dc3545;color:#fff}.btn-remove-filter:disabled{opacity:.3;cursor:not-allowed}.filter-row .filter-preview{color:var(--text-secondary);font-size:.75rem;font-style:italic;display:block;padding-left:0;margin-left:0}.add-filter-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-primary)}.btn-outline-primary{padding:.5rem 1rem;border:1px solid var(--color-primary, #0066cc);border-radius:.375rem;background:transparent;color:var(--color-primary, #0066cc);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;font-weight:500}.btn-outline-primary:hover{background:var(--color-primary, #0066cc);color:#fff}.rules-summary{margin-top:1.5rem}.alert{padding:.75rem 1rem;border-radius:.375rem;margin-bottom:1rem}.alert-info{background:#cfe2ff;border:1px solid #9ec5fe;color:#084298}.alert-warning{background:#fff3cd;border:1px solid #ffecb5;color:#664d03}.alert-danger{background:#f8d7da;border:1px solid #f5c2c7;color:#842029}.alert strong{font-weight:600}.alert ul{margin:.5rem 0 0 1.5rem;padding:0}.preview-section{border-top:1px solid var(--border-primary);padding-top:1rem;margin-top:1rem}.btn-primary{padding:.5rem 1.5rem;border:none;border-radius:.375rem;background:var(--color-primary, #0066cc);color:#fff;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;font-weight:500}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark, #0052a3)}.spinner-border{width:1rem;height:1rem;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spinner-border .75s linear infinite}@keyframes spinner-border{to{transform:rotate(360deg)}}.preview-results .card{margin-top:1rem;border:1px solid var(--border-primary);border-radius:.5rem;background:var(--bg-primary)}.preview-results .card-header{padding:1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);border-radius:.5rem .5rem 0 0}.preview-results .card-header h5{margin:0;color:var(--text-primary)}.preview-results .btn-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center}.preview-results .btn-close:hover{color:var(--text-primary)}.preview-results .btn-close:before{content:"×"}.preview-results .card-body{padding:1rem;background:var(--bg-primary);color:var(--text-primary)}.preview-results .row{margin-bottom:1rem}.preview-results strong{color:var(--text-primary);font-weight:600}.preview-results .badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.preview-results .bg-success{background:#198754;color:#fff}.preview-results .bg-secondary{background:#6c757d;color:#fff}.preview-results .table-responsive{max-height:400px;overflow-y:auto;border:1px solid var(--border-primary);border-radius:.375rem}.preview-results .table{width:100%;margin-bottom:0;color:var(--text-primary)}.preview-results .table thead{position:sticky;top:0;background:var(--bg-secondary);z-index:1}.preview-results .table th{padding:.75rem;border-bottom:2px solid var(--border-primary);font-weight:600;text-align:left}.preview-results .table td{padding:.75rem;border-bottom:1px solid var(--border-primary)}.preview-results .table tbody tr:hover{background:var(--bg-hover, #f0f0f0)}.preview-results .text-muted{color:var(--text-secondary)}.preview-results .text-center{text-align:center}@media(max-width:768px){.filter-row .col-md-3,.filter-row .col-md-5,.filter-row .col-md-1{width:100%;margin-bottom:.5rem}.filter-row .row{flex-direction:column}.logic-toggle{flex-direction:column;align-items:flex-start}}.distribution-lists-page{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem;height:100%;width:100%;box-sizing:border-box}.distribution-lists-page.with-rules-panel{grid-template-columns:minmax(400px,1fr) minmax(400px,2fr) minmax(400px,1fr)}.distribution-lists-page.loading{display:flex;justify-content:center;align-items:center;font-size:1.125rem;color:var(--text-secondary)}.lists-panel,.members-panel,.rules-panel,.info-panel{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden}.info-panel{border:1px solid var(--color-primary);background:linear-gradient(to bottom,var(--bg-primary),var(--bg-secondary))}.info-content{padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:center;text-align:center;flex:1}.info-content p{margin:0;font-size:.9375rem;color:var(--text-primary);line-height:1.6}.info-content strong{color:var(--color-primary);font-weight:600}.panel-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.panel-header .header-content{display:flex;justify-content:space-between;align-items:center;gap:1rem}.panel-header h2{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.panel-header .subtitle{margin-top:.25rem;font-size:.875rem;color:var(--text-secondary);font-weight:400}.btn-save-rules{padding:.5rem 1rem;background:var(--primary);color:#000;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:600;white-space:nowrap;transition:all var(--transition);display:flex;align-items:center;gap:.25rem}.btn-save-rules:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-save-rules:disabled{opacity:.6;cursor:not-allowed;transform:none}.create-form{padding:1rem;display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem;border-bottom:1px solid var(--border-primary)}.create-form input,.create-form select,.create-form textarea{padding:.5rem;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-family:inherit}.create-form textarea{resize:vertical;min-height:60px}.create-form .form-row-full{grid-column:1 / -1}.create-form input:focus,.create-form select:focus,.create-form textarea:focus{outline:none;border-color:var(--primary)}.create-form button{padding:.5rem 1rem;background:var(--primary);color:#000;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500;white-space:nowrap;align-self:start;transition:all var(--transition)}.create-form button:hover{background:var(--primary-hover)}.assign-form{padding:1rem;display:flex;gap:.5rem;border-bottom:1px solid var(--border-primary)}.assign-form select{flex:1;padding:.5rem;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.assign-form select:focus{outline:none;border-color:var(--primary)}.assign-form button{padding:.5rem 1rem;background:var(--primary);color:#000;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500;white-space:nowrap;transition:all var(--transition)}.assign-form button:hover{background:var(--primary-hover)}.assign-form button:disabled{background:var(--bg-tertiary);color:var(--text-disabled);cursor:not-allowed}.lists-list,.members-list{flex:1;overflow-y:auto;padding:.5rem}.list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;margin-bottom:.5rem;border:1px solid var(--border-primary);border-radius:8px;cursor:pointer;transition:all var(--transition);background:var(--bg-primary)}.list-item:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.list-item.selected{background:var(--selected-bg);border-color:var(--primary);box-shadow:0 0 0 2px #f59e0b1a}.list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.list-name{font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-type{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;font-weight:500}.member-count{font-size:.75rem;color:var(--text-secondary)}.member-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;margin-bottom:.5rem;border:1px solid var(--border-primary);border-radius:8px;transition:all var(--transition);background:var(--bg-primary)}.member-item:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.member-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.member-name{font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-type{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.delete-btn,.remove-btn{padding:.375rem;background:transparent;border:none;cursor:pointer;border-radius:4px;font-size:1rem;line-height:1;transition:all var(--transition);opacity:.6;color:var(--text-primary)}.delete-btn:hover,.remove-btn:hover{opacity:1;background:#ef44441a;color:#ef4444}.empty-state,.loading-state{display:flex;justify-content:center;align-items:center;padding:3rem 1rem;color:var(--text-secondary);font-size:.95rem;text-align:center}.loading-state{font-style:italic}@media(max-width:768px){.distribution-lists-page{grid-template-columns:1fr;height:auto}.lists-panel,.members-panel{max-height:500px}.create-form{grid-template-columns:1fr}.create-form button,.assign-form button{width:100%}}.dynamic-rules-section-inline{margin-top:1rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius);max-height:300px;overflow-y:auto}.dynamic-rules-section-inline h4{margin:0 0 .5rem;font-size:.875rem;font-weight:600;color:var(--text-primary)}.dynamic-rules-section-inline .hint{margin:0 0 1rem;font-size:.75rem;color:var(--text-secondary);font-style:italic}.rules-panel{background:var(--bg-primary);border:1px solid var(--color-primary);border-radius:var(--radius);box-shadow:0 2px 8px #0066cc1a}.rules-editor-container{padding:1rem;overflow-y:auto;flex:1}.form-row-full{grid-column:1 / -1}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#1a1a1a}.modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.modal-close:hover{color:#333}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e0e0e0}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:#333;font-size:.95rem}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.form-hint{display:block;margin-top:.25rem;font-size:.85rem;color:#666}.required{color:#dc3545}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer}.warning-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:6px;padding:1rem;margin-top:1rem;color:#856404;font-size:.9rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#f5f5f5;color:#333}.btn-secondary:hover:not(:disabled){background:#e0e0e0}[data-theme=dark] .modal-content{background:#1f2937}[data-theme=dark] .modal-header{border-bottom-color:#374151}[data-theme=dark] .modal-header h2{color:#e5e7eb}[data-theme=dark] .modal-close{color:#9ca3af}[data-theme=dark] .modal-close:hover{color:#e5e7eb}[data-theme=dark] .modal-footer{border-top-color:#374151}[data-theme=dark] .form-group label{color:#e5e7eb}[data-theme=dark] .form-group input,[data-theme=dark] .form-group textarea,[data-theme=dark] .form-group select{background:#374151;border-color:#4b5563;color:#e5e7eb}[data-theme=dark] .form-group input:disabled{background:#1f2937;color:#6b7280}@media(max-width:768px){.modal-content{max-width:100%;max-height:100vh;border-radius:0}.form-row{grid-template-columns:1fr}}.workflow-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:flex-start;z-index:1000;overflow-y:auto;padding:2rem 1rem}.workflow-modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;position:relative;margin:auto}.workflow-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;border-radius:12px 12px 0 0;z-index:10}.workflow-modal-header h2{margin:0;font-size:1.5rem;color:#1f2937}.btn-close{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-close:hover{background:#f3f4f6;color:#1f2937}.workflow-form{flex:1;overflow-y:auto;padding:1.5rem 1.5rem 0rem;display:flex;flex-direction:column;gap:2rem}.loading-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:20;border-radius:12px}.loading-overlay p{font-size:1.1rem;color:#6b7280}.form-section{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.form-section h3{margin:0 0 1rem;font-size:1.2rem;color:#1f2937;font-weight:600}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h3{margin:0}.section-actions{display:flex;gap:.5rem;align-items:center}.form-group{display:flex;flex-direction:column;gap:.5rem;flex:1}.form-group label{font-weight:500;color:#374151;font-size:.95rem}.field-note{font-weight:400;color:#6b7280;font-size:.85rem;font-style:italic}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:all .2s;background:#fff;color:#1f2937}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group select:disabled{background:#f3f4f6;cursor:not-allowed;color:#9ca3af}.form-group textarea{resize:vertical;min-height:60px;font-family:inherit}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}}.checkbox-group{display:flex;gap:1.5rem;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;color:#374151}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.checkbox-label span{font-size:.95rem}.btn-add-step{background:#3b82f6;color:#fff;border:none;padding:.625rem 1rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add-step:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-collapse-all,.btn-expand-all{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:.5rem .875rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-collapse-all:hover,.btn-expand-all:hover{background:#e5e7eb;border-color:#9ca3af;transform:translateY(-1px)}.btn-remove-step{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;opacity:.6}.btn-remove-step:hover{background:#fee2e2;opacity:1}.steps-list{display:flex;flex-direction:column;gap:1rem}.step-card{background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:1rem;cursor:move;transition:all .2s}.step-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a}.step-card.dragging{opacity:.5;transform:scale(.98)}.step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.step-number{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;color:#1f2937;flex:1}.step-name-preview{color:#6b7280;font-weight:400;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.step-actions{display:flex;gap:.5rem;align-items:center}.btn-toggle-step{background:#f3f4f6;border:none;font-size:1rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;color:#6b7280;min-width:32px}.btn-toggle-step:hover{background:#e5e7eb;color:#1f2937}.drag-handle{cursor:move;color:#9ca3af;font-size:1.2rem;-webkit-user-select:none;user-select:none}.step-body{display:flex;flex-direction:column;gap:1rem}.empty-state{text-align:center;padding:3rem 1rem;color:#6b7280}.empty-state p{margin-bottom:1rem;font-size:1.05rem}.summary-section{background:#eff6ff;border-color:#bfdbfe}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-label{font-size:.9rem;color:#6b7280;font-weight:500}.summary-value{font-size:1.5rem;color:#1f2937;font-weight:600}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e5e7eb;background:#fff;position:sticky;bottom:0;border-radius:0 0 12px 12px;z-index:10}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.text-muted{color:#9ca3af;font-size:.85rem;font-weight:400}[data-theme=dark] .workflow-modal-content{background:#1f2937}[data-theme=dark] .workflow-modal-header{background:#1f2937;border-bottom-color:#374151}[data-theme=dark] .workflow-modal-header h2{color:#e5e7eb}[data-theme=dark] .btn-close{color:#9ca3af}[data-theme=dark] .btn-close:hover{background:#374151;color:#e5e7eb}[data-theme=dark] .form-section{background:#111827;border-color:#374151}[data-theme=dark] .form-section h3{color:#e5e7eb}[data-theme=dark] .form-group label{color:#d1d5db}[data-theme=dark] .field-note{color:#9ca3af}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .form-group textarea{background:#374151;border-color:#4b5563;color:#e5e7eb}[data-theme=dark] .form-group input:focus,[data-theme=dark] .form-group select:focus,[data-theme=dark] .form-group textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33}[data-theme=dark] .form-group input:disabled,[data-theme=dark] .form-group select:disabled{background:#1f2937;color:#6b7280}[data-theme=dark] .checkbox-label{color:#d1d5db}[data-theme=dark] .step-card{background:#1f2937;border-color:#374151}[data-theme=dark] .step-card:hover{border-color:#60a5fa;box-shadow:0 4px 12px #60a5fa26}[data-theme=dark] .btn-collapse-all,[data-theme=dark] .btn-expand-all{background:#374151;color:#d1d5db;border-color:#4b5563}[data-theme=dark] .btn-collapse-all:hover,[data-theme=dark] .btn-expand-all:hover{background:#4b5563;border-color:#6b7280}[data-theme=dark] .step-header{border-bottom-color:#374151}[data-theme=dark] .step-number{color:#e5e7eb}[data-theme=dark] .step-name-preview{color:#9ca3af}[data-theme=dark] .btn-toggle-step{background:#374151;color:#9ca3af}[data-theme=dark] .btn-toggle-step:hover{background:#4b5563;color:#e5e7eb}[data-theme=dark] .drag-handle{color:#6b7280}[data-theme=dark] .empty-state{color:#9ca3af}[data-theme=dark] .summary-section{background:#1e3a5f;border-color:#2563eb}[data-theme=dark] .summary-label{color:#9ca3af}[data-theme=dark] .summary-value{color:#e5e7eb}[data-theme=dark] .form-actions{background:#1f2937;border-top-color:#374151}[data-theme=dark] .btn-secondary{background:#374151;color:#e5e7eb;border-color:#4b5563}[data-theme=dark] .btn-remove-step:hover{background:#991b1b}[data-theme=dark] .loading-overlay{background:#1f2937f2}[data-theme=dark] .loading-overlay p{color:#9ca3af}[data-theme=dark] .text-muted{color:#6b7280}@media(max-width:768px){.workflow-modal-overlay{padding:0}.workflow-modal-content{max-width:100%;max-height:100vh;border-radius:0}.workflow-modal-header,.form-actions{border-radius:0}.summary-grid{grid-template-columns:1fr}}.instance-viewer{max-width:1000px;max-height:90vh;overflow-y:auto}.instance-viewer .modal-body{display:flex;flex-direction:column;gap:2rem}.instance-overview{background:var(--bg-secondary);padding:1.5rem;border-radius:8px}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.overview-item{display:flex;flex-direction:column;gap:.5rem}.overview-item label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.overview-item span{font-size:1rem;color:var(--text-primary)}.progress-info{display:flex;flex-direction:column;gap:.5rem}.progress-bar-container{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s ease}.progress-percentage{font-weight:600;color:var(--primary-color)}.status-badge{display:inline-flex;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.badge-pending{background:#fef3c7;color:#92400e}.badge-in-progress{background:#dbeafe;color:#1e40af}.badge-completed{background:#d1fae5;color:#065f46}.badge-rejected{background:#fee2e2;color:#991b1b}.badge-canceled{background:#e5e7eb;color:#374151}.steps-timeline h3{margin-bottom:1.5rem;color:var(--text-primary)}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:1rem;top:0;bottom:0;width:2px;background:var(--border-color)}.timeline-item{position:relative;margin-bottom:2rem;padding-left:2rem}.timeline-item.current{background:var(--bg-hover);margin-left:-1rem;margin-right:-1rem;padding:1rem 1rem 1rem 3rem;border-radius:8px;border-left:3px solid var(--primary-color)}.timeline-marker{position:absolute;left:.25rem;top:0;width:2.5rem;height:2.5rem;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:1}.timeline-item.current .timeline-marker{border-color:var(--primary-color);background:var(--primary-color)}.timeline-item.aprobado .timeline-marker{border-color:#10b981;background:#10b981}.timeline-item.rechazado .timeline-marker{border-color:#ef4444;background:#ef4444}.step-number{font-weight:700;color:var(--text-secondary)}.timeline-item.current .step-number,.timeline-item.aprobado .step-number,.timeline-item.rechazado .step-number{color:#fff}.timeline-content{background:var(--bg-secondary);padding:1rem;border-radius:8px;border:1px solid var(--border-color)}.timeline-item.current .timeline-content{background:var(--bg-primary);border-color:var(--primary-color)}.step-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.step-header h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1.125rem}.step-status-badge{display:inline-flex;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.step-badge-pending{background:#fef3c7;color:#92400e}.step-badge-active{background:#dbeafe;color:#1e40af;animation:pulse 2s infinite}.step-badge-approved{background:#d1fae5;color:#065f46}.step-badge-rejected{background:#fee2e2;color:#991b1b}.step-badge-skipped{background:#e5e7eb;color:#6b7280}.step-badge-changes-requested{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.step-actions{display:flex;gap:.5rem}.btn-approve,.btn-delegate{padding:.5rem 1rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-approve{background:#10b981;color:#fff}.btn-approve:hover{background:#059669;transform:translateY(-1px)}.btn-delegate{background:#6366f1;color:#fff}.btn-delegate:hover{background:#4f46e5;transform:translateY(-1px)}.step-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.detail-row{display:flex;gap:.5rem}.detail-row label{font-weight:600;color:var(--text-secondary);min-width:100px}.detail-row span{color:var(--text-primary)}.text-danger{color:#ef4444!important;font-weight:600}.step-actions-history{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.step-actions-history h5{margin:0 0 .75rem;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.action-item{background:var(--bg-tertiary);padding:.75rem;border-radius:6px;margin-bottom:.5rem}.action-header{display:flex;gap:.75rem;align-items:center;margin-bottom:.5rem;flex-wrap:wrap}.action-user{font-weight:600;color:var(--text-primary)}.action-type{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.action-approved{background:#d1fae5;color:#065f46}.action-rejected{background:#fee2e2;color:#991b1b}.action-requestedchanges{background:#fef3c7;color:#92400e}.action-delegated{background:#e0e7ff;color:#3730a3}.action-date{font-size:.75rem;color:var(--text-secondary);margin-left:auto}.action-comments{margin:.5rem 0 0;font-size:.875rem;color:var(--text-secondary);font-style:italic}.action-delegation{margin:.5rem 0 0;font-size:.875rem;color:var(--primary-color);font-weight:500}.instance-stats{background:var(--bg-secondary);padding:1.5rem;border-radius:8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{text-align:center;padding:1rem;background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color)}.stat-card label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.stat-value{display:block;font-size:2rem;font-weight:700;color:var(--primary-color)}.modal-footer{display:flex;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.btn-restart-instance{padding:.75rem 1.5rem;background:#f59e0b;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;margin-right:auto}.btn-restart-instance:hover{background:#d97706;transform:translateY(-1px)}.btn-cancel-instance{padding:.75rem 1.5rem;background:#ef4444;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel-instance:hover{background:#dc2626;transform:translateY(-1px)}.btn-secondary{padding:.75rem 1.5rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--primary-color)}@media(prefers-color-scheme:dark){.badge-pending{background:#78350f;color:#fef3c7}.badge-in-progress{background:#1e3a8a;color:#dbeafe}.badge-completed{background:#064e3b;color:#d1fae5}.badge-rejected{background:#7f1d1d;color:#fee2e2}.step-badge-pending{background:#78350f;color:#fef3c7}.step-badge-active{background:#1e3a8a;color:#dbeafe}.step-badge-approved{background:#064e3b;color:#d1fae5}.step-badge-rejected{background:#7f1d1d;color:#fee2e2}.action-approved{background:#064e3b;color:#d1fae5}.action-rejected{background:#7f1d1d;color:#fee2e2}.action-requestedchanges{background:#78350f;color:#fef3c7}}.approval-modal{max-width:600px}.step-name-subtitle{margin:.5rem 0 0;font-size:.875rem;color:var(--text-secondary);font-weight:400}.action-buttons-group{display:flex;flex-direction:column;gap:.75rem}.action-button{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;text-align:left}.action-button:hover{border-color:var(--primary-color);background:var(--bg-hover);transform:translate(4px)}.action-button.active{border-color:currentColor;background:var(--bg-primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.action-button .action-icon{font-size:2rem;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-tertiary)}.action-button.active .action-icon{background:currentColor;color:#fff}.action-button .action-text{display:flex;flex-direction:column;gap:.25rem;flex:1}.action-button .action-text strong{font-size:1rem;color:var(--text-primary)}.action-button .action-text small{font-size:.875rem;color:var(--text-secondary);font-weight:400}.action-approve{color:#10b981}.action-approve.active{border-color:#10b981;background:#10b9811a}.action-reject{color:#ef4444}.action-reject.active{border-color:#ef4444;background:#ef44441a}.action-changes{color:#f59e0b}.action-changes.active{border-color:#f59e0b;background:#f59e0b1a}.info-box{display:flex;gap:1rem;padding:1rem;background:var(--bg-secondary);border-left:4px solid var(--primary-color);border-radius:4px;margin-top:1rem}.info-icon{font-size:1.5rem;margin:0}.info-content{flex:1}.info-content strong{display:block;margin-bottom:.5rem;color:var(--text-primary)}.info-content p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.required-indicator{color:#ef4444;font-weight:600;font-size:.875rem}.btn-submit-approved{background:#10b981}.btn-submit-approved:hover:not(:disabled){background:#059669}.btn-submit-rejected{background:#ef4444}.btn-submit-rejected:hover:not(:disabled){background:#dc2626}.btn-submit-requestedchanges{background:#f59e0b}.btn-submit-requestedchanges:hover:not(:disabled){background:#d97706}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:.5rem}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-color-scheme:dark){.action-approve.active{background:#10b98133}.action-reject.active{background:#ef444433}.action-changes.active{background:#f59e0b33}}.delegate-modal{max-width:600px;width:90%}.delegate-modal .modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;align-items:center}.delegate-modal .modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.delegate-modal .close-btn{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.delegate-modal .close-btn:hover{background:#ffffff4d}.delegate-modal .modal-body{padding:1.5rem}.delegate-info{background:#f3f4f6;padding:1rem;border-radius:6px;margin-bottom:1.5rem;border-left:4px solid #667eea}.delegate-info p{margin:.5rem 0;color:#374151}.delegate-info p:first-child{margin-top:0}.delegate-info p:last-child{margin-bottom:0}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#374151;font-size:.95rem}.form-group .required{color:#dc2626;font-weight:700}.form-group .optional{color:#6b7280;font-weight:400;font-size:.85rem}.form-control{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.form-control:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-control:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.form-control select:disabled{opacity:.6}.form-hint{display:block;margin-top:.5rem;font-size:.85rem;color:#6b7280}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.btn-secondary,.btn-primary{padding:.75rem 1.5rem;border-radius:6px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .delegate-modal .modal-body{background:#1f2937}[data-theme=dark] .delegate-info{background:#374151;border-left-color:#818cf8}[data-theme=dark] .delegate-info p,[data-theme=dark] .form-group label{color:#e5e7eb}[data-theme=dark] .form-control{background:#374151;border-color:#4b5563;color:#e5e7eb}[data-theme=dark] .form-control:focus{border-color:#818cf8;box-shadow:0 0 0 3px #818cf81a}[data-theme=dark] .form-control:disabled{background:#1f2937;color:#9ca3af}[data-theme=dark] .form-hint{color:#9ca3af}[data-theme=dark] .btn-secondary{background:#374151;color:#e5e7eb}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:#4b5563}[data-theme=dark] .error-message{background:#7f1d1d;border-color:#991b1b;color:#fca5a5}.approval-workflows-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:600;color:#1a1a1a;margin:0 0 .5rem}.page-description{color:#666;font-size:.95rem;margin:0}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.permission-denied{text-align:center;padding:3rem;background:#fff3cd;border:1px solid #ffc107;border-radius:8px}.permission-denied h2{color:#856404;margin:0 0 1rem}.permission-denied p{color:#856404;margin:0}.tabs{display:flex;gap:.5rem;border-bottom:2px solid #e0e0e0;margin-bottom:2rem}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#666;display:flex;align-items:center;gap:.5rem;transition:all .2s}.tab:hover{color:#333;background:#f5f5f5}.tab.active{color:#007bff;border-bottom-color:#007bff}.tab-icon{font-size:1.2rem}.tab-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a;max-height:calc(100vh - 300px);overflow-y:auto;scroll-behavior:smooth}.tab-content::-webkit-scrollbar{width:8px}.tab-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.tab-content::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.tab-content::-webkit-scrollbar-thumb:hover{background:#555}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.tab-header h2{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin:0}.tab-actions,.filters{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.btn-primary{padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:background .2s}.btn-primary:hover{background:#0056b3}.btn-icon{padding:.25rem .5rem;background:none;border:none;cursor:pointer;font-size:1.2rem;transition:transform .2s}.btn-icon:hover{transform:scale(1.2)}.btn-icon.btn-danger:hover,.btn-icon.btn-success:hover{filter:brightness(1.2)}.action-buttons{display:flex;gap:.5rem;align-items:center}.filter-select{padding:.5rem 1rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;background:#fff;cursor:pointer}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:#666;cursor:pointer}.checkbox-label input[type=checkbox]{width:1.2rem;height:1.2rem;cursor:pointer}.data-table{width:100%;border-collapse:collapse;font-size:.95rem}.data-table thead{background:#f8f9fa;border-bottom:2px solid #dee2e6}.data-table th{padding:.75rem;text-align:left;font-weight:600;color:#495057}.data-table td{padding:.75rem;border-bottom:1px solid #dee2e6;vertical-align:middle}.data-table tbody tr:hover{background:#f8f9fa}.data-table tr.deleted{opacity:.6;background:#f8f9fa}.text-muted{color:#6c757d}.small{font-size:.85rem}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.badge-active{background:#d4edda;color:#155724}.badge-inactive{background:#f8d7da;color:#721c24}.badge-system{background:#d1ecf1;color:#0c5460;display:flex;align-items:center;gap:.25rem}.badge-deleted{background:#e2e3e5;color:#383d41}.badge-pendiente{background:#fff3cd;color:#856404}.badge-en_proceso{background:#cce5ff;color:#004085}.badge-aprobado{background:#d4edda;color:#155724}.badge-rechazado{background:#f8d7da;color:#721c24}.badge-cancelado{background:#e2e3e5;color:#383d41}.entity-badge{display:inline-block;padding:.15rem .5rem;background:#e7f3ff;color:#06c;border-radius:4px;font-size:.8rem;font-weight:500;margin-right:.5rem}.progress-bar{width:100px;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;display:inline-block;vertical-align:middle;margin-right:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width .3s}.progress-text{font-size:.85rem;color:#6c757d}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.category-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s}.category-card:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26}.category-card.inactive{opacity:.7;background:#f8f9fa}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.category-header h3{margin:0;font-size:1.25rem;color:#1a1a1a}.category-code{background:#007bff;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.category-description{color:#666;font-size:.95rem;margin:0 0 1rem;line-height:1.5}.category-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #e0e0e0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.stat-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:1.25rem;transition:all .2s}.stat-card:hover{border-color:#28a745;box-shadow:0 4px 12px #28a74526}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e0e0e0}.stat-header h3{margin:0;font-size:1.15rem;color:#1a1a1a}.stat-code{background:#28a745;color:#fff;padding:.25rem .65rem;border-radius:12px;font-size:.8rem;font-weight:600}.stat-body{display:flex;flex-direction:column;gap:.5rem}.stat-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:.4rem .5rem;border-radius:4px}.stat-row:hover{background:#f8f9fa}.stat-label{color:#666;font-size:.9rem}.stat-value{font-weight:600;font-size:1.1rem;color:#1a1a1a}.stat-value.stat-pending{color:#ffc107}.stat-value.stat-inprogress{color:#007bff}.stat-value.stat-approved{color:#28a745}.stat-value.stat-rejected{color:#dc3545}.stat-value.stat-canceled{color:#6c757d}.stat-row.stat-alert{background:#fff3cd;border:1px solid #ffc107;font-weight:500}.stat-row.stat-highlight{background:#e7f3ff;border:1px solid #007bff;margin-top:.5rem}.empty-state{text-align:center;padding:3rem;color:#666}.empty-state p{font-size:1.1rem;margin:0 0 1.5rem}@media(max-width:768px){.approval-workflows-page{padding:1rem}.tab-content{padding:1rem;max-height:calc(100vh - 270px)}.tab-header{flex-direction:column;align-items:flex-start}.tab-actions,.filters{width:100%;flex-direction:column;align-items:stretch}.filter-select,.btn-primary{width:100%}.data-table{font-size:.85rem}.data-table th,.data-table td{padding:.5rem}.categories-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}}[data-theme=dark] .page-header h1{color:#e5e7eb}[data-theme=dark] .page-description,[data-theme=dark] .loading{color:#9ca3af}[data-theme=dark] .tab-content::-webkit-scrollbar-track{background:#374151}[data-theme=dark] .tab-content::-webkit-scrollbar-thumb{background:#6b7280}[data-theme=dark] .tab-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}[data-theme=dark] .tab{color:#9ca3af}[data-theme=dark] .tab:hover{color:#e5e7eb;background:#374151}[data-theme=dark] .tab.active{color:#60a5fa;border-bottom-color:#60a5fa}[data-theme=dark] .tab-content{background:#1f2937}[data-theme=dark] .tab-header h2{color:#e5e7eb}[data-theme=dark] .filter-select{background:#374151;border-color:#4b5563;color:#e5e7eb}[data-theme=dark] .checkbox-label{color:#9ca3af}[data-theme=dark] .data-table{color:#e5e7eb}[data-theme=dark] .data-table thead{background:#374151}[data-theme=dark] .data-table th{color:#e5e7eb}[data-theme=dark] .data-table td{border-bottom-color:#374151}[data-theme=dark] .data-table tbody tr:hover,[data-theme=dark] .data-table tr.deleted{background:#374151}[data-theme=dark] .text-muted{color:#9ca3af}[data-theme=dark] .category-card{background:#1f2937;border-color:#374151}[data-theme=dark] .category-card:hover{border-color:#60a5fa;box-shadow:0 4px 12px #60a5fa26}[data-theme=dark] .category-card.inactive{background:#111827}[data-theme=dark] .category-header h3{color:#e5e7eb}[data-theme=dark] .category-description{color:#9ca3af}[data-theme=dark] .category-footer{border-top-color:#374151}[data-theme=dark] .badge-system{background:#164e63;color:#67e8f9}[data-theme=dark] .stat-card{background:#1f2937;border-color:#374151}[data-theme=dark] .stat-card:hover{border-color:#34d399;box-shadow:0 4px 12px #34d39926}[data-theme=dark] .stat-header{border-bottom-color:#374151}[data-theme=dark] .stat-header h3{color:#e5e7eb}[data-theme=dark] .stat-label{color:#9ca3af}[data-theme=dark] .stat-value{color:#e5e7eb}[data-theme=dark] .stat-row:hover{background:#374151}[data-theme=dark] .empty-state,[data-theme=dark] .empty-state p{color:#9ca3af}[data-theme=dark] .entity-badge{background:#1e3a8a;color:#93c5fd}[data-theme=dark] .progress-bar{background:#374151}[data-theme=dark] .progress-text{color:#9ca3af}
