:root{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:#1f2937;background:#eef2f7}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,#eef2f7,#f8fafc)}h1,h2,h3,p{margin:0}.app-shell{display:grid;grid-template-columns:288px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#0f2f57,#0a2445);color:#fff;padding:24px 20px;display:flex;flex-direction:column;gap:24px}.brand-block{display:flex;gap:12px;align-items:flex-start}.brand-icon{width:42px;height:42px;border-radius:12px;background:#ffffff2e;display:grid;place-items:center;font-size:1.2rem}.sidebar h1{font-size:1rem;letter-spacing:.04em;white-space:normal}.sidebar p{color:#cbd5e1;margin-top:5px;font-size:.86rem}.main-nav,.nav-visual-group{display:flex;flex-direction:column;gap:8px}.nav-visual-group{margin-top:auto}.nav-visual-group small{color:#9fb4cb;text-transform:uppercase;font-size:.7rem;letter-spacing:.08em;padding-left:10px}.nav-link{display:flex;align-items:center;gap:10px;color:#e2e8f0;text-decoration:none;padding:10px 12px;border-radius:10px;border:1px solid transparent}.nav-link.active,.nav-link:hover{background:#1e4e8999;border-color:#ffffff2e}.nav-link-muted{opacity:.6;cursor:default}.app-content{display:flex;flex-direction:column}.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;background:#fff;border-bottom:1px solid #e5e7eb}.topbar p{margin-top:4px;color:#64748b}.topbar-actions{display:flex;align-items:center;gap:12px}.notification-pill{width:36px;height:36px;border-radius:999px;background:#f1f5f9;display:grid;place-items:center}main{padding:24px}.card{background:#fff;border-radius:16px;box-shadow:0 10px 24px #0f172a14;padding:20px}.dashboard-page{display:flex;flex-direction:column;gap:16px}.dashboard-header h2{font-size:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.stat-card{border-top:4px solid transparent;display:flex;flex-direction:column;gap:8px}.stat-icon{width:50px;height:50px;border-radius:999px;display:grid;place-items:center;font-size:1.25rem}.stat-card h3{font-size:.92rem;color:#64748b}.stat-card p{font-size:2rem;font-weight:700;line-height:1.1}.stat-card small{color:#64748b}.stat-blue{border-top-color:#2563eb}.stat-blue .stat-icon{background:#dbeafe}.stat-green{border-top-color:#16a34a}.stat-green .stat-icon{background:#dcfce7}.stat-orange{border-top-color:#ea580c}.stat-orange .stat-icon{background:#ffedd5}.stat-red{border-top-color:#dc2626}.stat-red .stat-icon{background:#fee2e2}.dashboard-bottom-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.info-card p{margin-top:10px;color:#334155;line-height:1.5}.status-row{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px}.status-row span{font-size:.84rem;color:#334155;background:#f8fafc;border-radius:999px;padding:7px 10px}.quick-actions{display:flex;flex-direction:column;gap:10px}.action-card{border:1px solid #e2e8f0;background:#fff;border-radius:12px;text-align:left;padding:11px 12px;cursor:pointer}.action-card:hover{background:#f8fafc;border-color:#cbd5e1}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(420px,100%);display:flex;flex-direction:column;gap:12px}input{border:1px solid #d1d5db;border-radius:10px;padding:10px 12px}.btn{border:0;border-radius:10px;padding:10px 14px;background:#1d4ed8;color:#fff;cursor:pointer}.btn-danger{background:#dc2626}.btn:disabled{opacity:.7;cursor:not-allowed}.error-text{color:#b91c1c}.muted{color:#64748b;margin-top:6px}.state{background:#fff;border-radius:14px;padding:24px;text-align:center}.state.fullscreen{min-height:100vh;display:grid;place-content:center}.spinner{width:28px;height:28px;border-radius:50%;border:3px solid #cbd5e1;border-top-color:#1d4ed8;margin:0 auto 12px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1024px){.app-shell{grid-template-columns:1fr}.nav-visual-group{margin-top:8px}.dashboard-bottom-grid{grid-template-columns:1fr}}.empresas-toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.btn-light{background:#f8fafc;color:#0f172a;border:1px solid #cbd5e1}.table-wrap{width:100%;overflow:auto;border:1px solid #e2e8f0;border-radius:12px}.empresas-table{width:100%;border-collapse:collapse;min-width:980px}.empresas-table th,.empresas-table td{padding:12px;border-bottom:1px solid #e5e7eb;text-align:left;font-size:.9rem}.empresas-table th{background:#f8fafc;color:#475569;font-weight:600}.row-actions{display:flex;gap:8px}.status-pill{border-radius:999px;padding:4px 10px;font-size:.76rem;font-weight:600}.status-pill.active{background:#dcfce7;color:#166534}.status-pill.inactive{background:#fee2e2;color:#991b1b}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;z-index:50;padding:16px}.modal-card{width:min(880px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:16px;box-shadow:0 24px 60px #0f172a40;padding:20px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.empresa-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field-group{display:flex;flex-direction:column;gap:6px;font-size:.86rem;color:#475569;text-transform:capitalize}.field-group input,.field-group textarea{width:100%}.field-full{grid-column:1/-1}.modal-actions{grid-column:1/-1;display:flex;justify-content:flex-end;gap:10px;margin-top:4px}@media (max-width: 768px){.empresa-form{grid-template-columns:1fr}}select{border:1px solid #d1d5db;border-radius:10px;padding:10px 12px;background:#fff}.personal-toolbar{grid-template-columns:1.2fr repeat(2,minmax(180px,auto)) auto;align-items:center}.personal-table td strong{color:#0f172a}.status-pill.external{background:#dbeafe;color:#1e40af}.status-pill.terminated{background:#e5e7eb;color:#334155}.badge{border-radius:999px;padding:4px 9px;font-size:.74rem;font-weight:700;display:inline-flex;align-items:center}.priority-low{background:#e2e8f0;color:#334155}.priority-medium{background:#dbeafe;color:#1d4ed8}.priority-high{background:#ffedd5;color:#c2410c}.priority-critical{background:#fee2e2;color:#b91c1c}.status-pending{background:#e5e7eb;color:#374151}.status-progress{background:#dbeafe;color:#1d4ed8}.status-blocked{background:#ffedd5;color:#c2410c}.status-completed{background:#dcfce7;color:#166534}.status-cancelled{background:#fee2e2;color:#991b1b}.overdue-badge{margin-left:8px;background:#fecaca;color:#991b1b}.critical-row td:first-child,.critical-row td:nth-child(2){background:#fff7f7}.dashboard-header-flex{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.dashboard-panels-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.progress-list{display:flex;flex-direction:column;gap:12px;margin-top:10px}.progress-head{display:flex;justify-content:space-between;font-size:.9rem;color:#334155;margin-bottom:6px}.progress-track{width:100%;height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden}.progress-fill{height:100%;border-radius:999px}.progress-gray{background:#64748b}.progress-blue{background:#2563eb}.progress-orange{background:#ea580c}.progress-green{background:#16a34a}.progress-red{background:#dc2626}.alerts-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}.alert-pill{border-radius:10px;padding:10px 12px;font-size:.9rem;font-weight:600}.alert-pill.warn{background:#ffedd5;color:#9a3412}.alert-pill.danger{background:#fee2e2;color:#991b1b}.alert-pill.info{background:#fef9c3;color:#854d0e}.alert-pill.stable{background:#dcfce7;color:#166534}.dashboard-table-card h3{margin-bottom:12px}.dashboard-table{min-width:740px}@media (max-width: 1024px){.dashboard-panels-grid{grid-template-columns:1fr}}.infosistec-section{display:flex;flex-direction:column;gap:14px}.infosistec-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}.infosistec-badge{border-radius:999px;padding:6px 10px;background:#dbeafe;color:#1e40af;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.infosistec-grid{margin-top:4px}.infosistec-note{color:#475569;font-size:.88rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px}.infosistec-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:10px;padding:10px 12px;font-weight:600}.sidebar-separator{height:1px;background:#94a3b859;margin:2px 4px}.integrated-nav-group{display:flex;flex-direction:column;gap:8px}.integrated-nav-group small{color:#9fb4cb;text-transform:uppercase;font-size:.7rem;letter-spacing:.08em;padding-left:10px}.integrated-link{border:1px solid rgba(255,255,255,.12);background:#0f2a4a73;color:#e2e8f0;border-radius:12px;padding:10px 12px;text-align:left;display:flex;flex-direction:column;gap:2px;cursor:pointer}.integrated-link strong{font-size:.83rem;letter-spacing:.02em}.integrated-link span{font-size:.76rem;color:#bfd0e3}.integrated-link:hover,.integrated-link.active{background:#1e4e899e;border-color:#fff3}.integration-placeholder{display:flex;flex-direction:column;gap:12px}.integration-placeholder-header{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;align-items:flex-start}.integration-badge{border-radius:999px;padding:6px 10px;background:#ede9fe;color:#5b21b6;font-size:.76rem;font-weight:700}.integration-status{color:#0f172a;font-weight:700;font-size:1.05rem}.integration-message{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px}
