@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--font-primary:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--color-bg-primary:#f8fafc;--color-bg-secondary:#fff;--color-primary:#0598ce;--color-primary-hover:#0482b0;--color-primary-light:#e6f6fc;--color-secondary:#113768;--color-secondary-hover:#0c274b;--color-dark-deep:#001a33;--color-text-primary:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-border:#e2e8f0;--color-border-hover:#cbd5e1;--color-pending-bg:#fffbeb;--color-pending-text:#b45309;--color-pending-border:#fde68a;--color-progress-bg:#eff6ff;--color-progress-text:#1d4ed8;--color-progress-border:#bfdbfe;--color-completed-bg:#f0fdf4;--color-completed-text:#15803d;--color-completed-border:#bbf7d0;--color-danger-bg:#fef2f2;--color-danger-text:#b91c1c;--color-danger-border:#fca5a5;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--transition-fast:all .15s cubic-bezier(.4, 0, .2, 1);--transition-normal:all .25s cubic-bezier(.4, 0, .2, 1);--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-primary);background-color:var(--color-bg-primary);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}button,input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#94a3b880;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#64748bcc}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}.animate-scale-in{animation:scaleIn var(--transition-normal) forwards}.gastos-view{padding:24px}.gastos-table-container{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0003}.badge-categoria{color:#60a5fa;background:#3b82f633;border-radius:4px;padding:4px 8px;font-size:.85rem}.amount-col{color:#fff;font-weight:600}.status-badge{border-radius:12px;align-items:center;gap:4px;padding:4px 8px;font-size:.85rem;display:inline-flex}.status-badge.pagado{color:#34d399;background:#10b98133}.status-badge.pendiente{color:#fbbf24;background:#f59e0b33}.file-link{color:#60a5fa;align-items:center;gap:4px;text-decoration:none;display:inline-flex}.file-link:hover{text-decoration:underline}.estadistica-view{padding:24px}.filters{background:var(--card-bg);border-radius:8px;align-items:center;gap:8px;padding:8px 16px;display:flex}.filters select{color:#fff;cursor:pointer;background:0 0;border:none;font-size:1rem;font-weight:600}.stats-grid{grid-template-columns:1fr 1fr;gap:24px;margin-top:24px;display:grid}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:24px;display:grid}.kpi-card{background:var(--card-bg);border-radius:12px;align-items:center;gap:16px;padding:20px;display:flex;box-shadow:0 4px 6px #0003}.kpi-icon{color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.kpi-icon.ingresos{color:#10b981;background:#10b98133}.kpi-icon.egresos{color:#ef4444;background:#ef444433}.kpi-icon.ganancia{color:#3b82f6;background:#3b82f633}.kpi-icon.margen{color:#f59e0b;background:#f59e0b33}.kpi-info{flex-direction:column;display:flex}.kpi-title{color:#94a3b8;font-size:.9rem;font-weight:500}.kpi-value{color:#f1f5f9;margin-top:4px;font-size:1.5rem;font-weight:700}.chart-card{background:var(--card-bg);border-radius:12px;padding:20px;box-shadow:0 4px 6px #0003}.chart-card.full-width{grid-column:1/-1}.chart-card h3{color:#f1f5f9;margin-top:0;margin-bottom:24px;font-size:1.1rem}.custom-tooltip{background:#0f172ae6;border:1px solid #334155;border-radius:8px;padding:12px}.custom-tooltip .label{color:#fff;margin:0 0 8px;font-weight:700}.custom-tooltip p{margin:4px 0;font-size:.9rem}.app-container{background-color:var(--color-bg-primary);min-height:100vh;display:flex}.sidebar{background-color:var(--color-secondary);color:#fff;width:260px;box-shadow:var(--shadow-md);transition:var(--transition-normal);z-index:10;border-right:1px solid #ffffff1a;flex-direction:column;flex-shrink:0;display:flex}.sidebar-header{border-bottom:1px solid #ffffff1a;align-items:center;gap:6px;padding:24px;display:flex}.sidebar-logo{object-fit:contain;width:auto;height:65px;margin-top:6px}.sidebar-brand{letter-spacing:.5px;color:#fff;font-size:1.15rem;font-weight:700}.sidebar-brand span{color:var(--color-primary)}.sidebar-menu{flex-direction:column;flex:1;gap:8px;padding:20px 12px;display:flex}.sidebar-item{border-radius:var(--radius-md);color:#ffffffb3;cursor:pointer;transition:var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 16px;font-weight:500;display:flex}.sidebar-item:hover{color:#fff;background-color:#ffffff14}.sidebar-item.active{color:#fff;background-color:var(--color-primary);box-shadow:0 4px 12px #0598ce40}.sidebar-footer{background-color:#00000026;border-top:1px solid #ffffff1a;flex-direction:column;gap:12px;padding:16px 20px;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:#fff;font-size:.9rem;font-weight:600}.user-role{color:var(--color-text-muted);font-size:.75rem}.btn-logout{border-radius:var(--radius-sm);color:#ef4444;cursor:pointer;transition:var(--transition-fast);background-color:#ef444426;border:1px solid #ef444433;justify-content:center;align-items:center;gap:8px;padding:8px;font-size:.85rem;font-weight:600;display:flex}.btn-logout:hover{color:#fff;background-color:#ef4444}.main-content{flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden}.top-navbar{background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;height:70px;padding:0 32px;display:flex}.page-title{color:var(--color-secondary);font-size:1.4rem;font-weight:700}.navbar-actions{align-items:center;gap:16px;display:flex}.content-wrapper{flex:1;padding:32px;overflow-y:auto}.auth-container{background:radial-gradient(circle at 10% 20%,#113768f2 0%,#001a33fa 90%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);background:#fffffffa;padding:40px;animation:.3s scaleIn}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{height:60px;margin-bottom:16px}.auth-title{color:var(--color-secondary);font-size:1.5rem;font-weight:700}.auth-subtitle{color:var(--color-text-secondary);margin-top:8px;font-size:.9rem}.form-group{margin-bottom:20px}.form-label{color:var(--color-text-primary);margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.form-input{border-radius:var(--radius-md);border:1px solid var(--color-border);width:100%;color:var(--color-text-primary);transition:var(--transition-fast);background-color:#fff;outline:none;padding:12px 16px;font-size:.95rem}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0598ce26}.btn-primary{border-radius:var(--radius-md);background-color:var(--color-primary);color:#fff;cursor:pointer;width:100%;transition:var(--transition-fast);border:none;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:1rem;font-weight:600;display:flex}.btn-primary:hover{background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0598ce33}.btn-primary:active{transform:translateY(0)}.auth-footer{text-align:center;color:var(--color-text-secondary);margin-top:24px;font-size:.9rem}.auth-link{color:var(--color-primary);cursor:pointer;font-weight:600}.auth-link:hover{text-decoration:underline}.kanban-view-container{flex-direction:column;gap:20px;height:100%;display:flex}.tabs-container{border-bottom:2px solid var(--color-border);gap:8px;padding-bottom:2px;display:flex}.tab-btn{color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;padding:12px 24px;font-size:.95rem;font-weight:600;position:relative}.tab-btn:hover{color:var(--color-secondary)}.tab-btn.active{color:var(--color-primary)}.tab-btn.active:after{content:"";background-color:var(--color-primary);height:2px;position:absolute;bottom:-2px;left:0;right:0}.kanban-board{flex:1;grid-template-columns:repeat(4,minmax(300px,1fr));gap:20px;height:100%;min-height:0;display:grid;overflow-x:auto}.kanban-column{border-radius:var(--radius-lg);border:1px solid var(--color-border);background-color:#f1f5f9;flex-direction:column;gap:16px;max-height:100%;padding:16px;display:flex;overflow-y:auto}.column-header{justify-content:space-between;align-items:center;padding:4px 8px;display:flex}.column-title-container{align-items:center;gap:8px;display:flex}.column-badge{background-color:var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-full);padding:2px 8px;font-size:.8rem;font-weight:600}.column-title{color:var(--color-secondary);font-size:1rem;font-weight:700}.btn-add-card{color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.btn-add-card:hover{background-color:var(--color-border);color:var(--color-secondary)}.cards-container{flex-direction:column;flex:1;gap:12px;min-height:100px;display:flex}.kanban-card{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:grab;transition:var(--transition-fast);background-color:#fff;flex-direction:column;gap:12px;padding:16px;display:flex}.kanban-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-hover);transform:translateY(-1px)}.card-title{color:var(--color-dark-deep);font-size:.95rem;font-weight:600}.card-description{color:var(--color-text-secondary);font-size:.85rem;line-height:1.4}.card-meta{color:var(--color-text-muted);border-top:1px solid var(--color-bg-primary);justify-content:space-between;align-items:center;margin-top:4px;padding-top:10px;font-size:.8rem;display:flex}.card-badge{border-radius:var(--radius-full);padding:2px 8px;font-size:.75rem;font-weight:600}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background-color:#0006;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);background-color:#fff;padding:32px;animation:.2s scaleIn;position:relative}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{color:var(--color-secondary);font-size:1.25rem;font-weight:700}.btn-close{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;font-size:1.25rem}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.btn-secondary{border-radius:var(--radius-md);border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;transition:var(--transition-fast);background-color:#0000;padding:10px 20px;font-weight:600}.btn-secondary:hover{background-color:var(--color-bg-primary)}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-bottom:32px;display:grid}.stat-card{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:var(--transition-fast);background-color:#fff;justify-content:space-between;align-items:center;padding:24px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-info{flex-direction:column;gap:4px;display:flex}.stat-label{color:var(--color-text-secondary);font-size:.85rem;font-weight:500}.stat-value{color:var(--color-secondary);font-size:1.8rem;font-weight:700}.stat-icon{background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.table-container{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);background-color:#fff;overflow:hidden}.table-header-bar{border-bottom:1px solid var(--color-border);background-color:#fafbfc;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.table-search{border-radius:var(--radius-md);border:1px solid var(--color-border);outline:none;width:260px;padding:8px 16px;font-size:.9rem}.table-search:focus{border-color:var(--color-primary)}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th{color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);background-color:#f8fafc;padding:16px 24px;font-size:.85rem;font-weight:600}.data-table td{color:var(--color-text-primary);border-bottom:1px solid var(--color-border);padding:16px 24px;font-size:.9rem}.data-table tr:hover{background-color:#fafbfc}.status-badge{border-radius:var(--radius-full);align-items:center;gap:6px;padding:4px 10px;font-size:.8rem;font-weight:600;display:inline-flex}.status-pending{background-color:var(--color-pending-bg);color:var(--color-pending-text);border:1px solid var(--color-pending-border)}.status-progress{background-color:var(--color-progress-bg);color:var(--color-progress-text);border:1px solid var(--color-progress-border)}.status-billing{color:#7e22ce;background-color:#f3e8ff;border:1px solid #e9d5ff}.status-completed{background-color:var(--color-completed-bg);color:var(--color-completed-text);border:1px solid var(--color-completed-border)}.status-danger{background-color:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}.searchable-select-container{width:100%;position:relative}.searchable-dropdown-list{border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;background-color:#fff;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.searchable-dropdown-item{color:var(--color-text-primary);cursor:pointer;transition:var(--transition-fast);justify-content:space-between;align-items:center;padding:10px 16px;font-size:.85rem;display:flex}.searchable-dropdown-item:hover{background-color:var(--color-bg-primary);color:var(--color-primary)}.searchable-dropdown-item.disabled{color:var(--color-text-muted);cursor:not-allowed;background-color:#fafafa}.mobile-menu-btn,.sidebar-overlay{display:none}@media (width<=768px){.app-container{flex-direction:column}.mobile-menu-btn{display:block}.hidden-on-mobile{display:none!important}.sidebar{z-index:1000;width:260px;height:100vh;transition:left .3s;position:fixed;top:0;left:-280px}.sidebar.mobile-open{left:0}.sidebar-overlay{z-index:999;background:#00000080;width:100vw;height:100vh;display:block;position:fixed;top:0;left:0}.main-content{width:100%;margin-left:0}.top-navbar{padding:12px 16px}.content-wrapper{padding:12px}.table-container,.gastos-table-container{overflow-x:auto!important}.table-header-bar,.modal-header,.card-meta{flex-wrap:wrap;gap:12px}.tabs-container{flex-wrap:wrap}.tab-btn{border-bottom:2px solid #0000;flex:100%;justify-content:center}.kanban-view-container{gap:12px}.table-search{width:100%!important}.btn-primary,.btn-secondary,.btn-add-card,.btn-logout{justify-content:center;width:100%}}
