@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-family:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--bg-primary:#f3f4f6;--bg-secondary:#fff;--text-primary:#1f2937;--text-secondary:#4b5563;--color-primary:#193769;--color-primary-rgb:25, 55, 105;--color-primary-hover:#122b54;--color-accent:#d4af37;--color-accent-hover:#c49e2b;--color-success:#10b981;--color-danger:#ef4444;--border-color:#e5e7eb;--input-bg:#f9fafb;--sidebar-bg:#091730;--sidebar-border:#ffffff14;--sidebar-text:#ffffffd9;--sidebar-text-secondary:#ffffff80;--sidebar-hover-bg:#ffffff0f;--sidebar-active-bg:#1c3b7a;--sidebar-active-hover-bg:#234b99;--glass-bg:#ffffffb3;--glass-border:#fff6;--glass-shadow:#19376914;--transition-fast:.2s ease;--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--shadow-sm:0 1px 3px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a}[data-theme=dark]{--bg-primary:#090d16;--bg-secondary:#101622;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--color-primary:#294c86;--color-primary-rgb:41, 76, 134;--color-primary-hover:#33599a;--color-accent:#e5c058;--color-accent-hover:#f3ce6b;--border-color:#1e293b;--input-bg:#151e2e;--sidebar-bg:#071020;--sidebar-border:#ffffff0f;--sidebar-text:#ffffffd9;--sidebar-text-secondary:#fff6;--sidebar-hover-bg:#ffffff0d;--sidebar-active-bg:#1a3360;--sidebar-active-hover-bg:#203f75;--glass-bg:#101622bf;--glass-border:#ffffff0f;--glass-shadow:#00000059}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background-color var(--transition-normal), color var(--transition-normal);-webkit-font-smoothing:antialiased;overflow-x:hidden}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px 0 var(--glass-shadow);transition:background var(--transition-normal), border var(--transition-normal), box-shadow var(--transition-normal)}.glass-card{composes:glass-panel;border-radius:var(--radius-md);padding:24px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:rgba(var(--color-primary-rgb), .2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:rgba(var(--color-primary-rgb), .4)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}.table-responsive{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.app-container{min-height:100vh;display:flex;position:relative}.sidebar{z-index:100;border-right:1px solid var(--sidebar-border);background-color:var(--sidebar-bg);width:300px;height:100vh;transition:transform var(--transition-normal), width var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:0;left:0;transform:translate(0)}.sidebar:not(.open){transform:translate(-100%)}.sidebar-header{border-bottom:1px solid var(--sidebar-border);align-items:center;gap:12px;padding:24px;display:flex}.logo-img{object-fit:contain;height:38px}.isotipo-img{object-fit:contain;height:32px}.sidebar-menu{flex:1;padding:16px 12px;overflow-y:auto}.menu-section-title{text-transform:uppercase;color:var(--sidebar-text-secondary);letter-spacing:.05em;padding:12px 16px 6px;font-size:.75rem;font-weight:700}.menu-item-row{border-radius:var(--radius-sm);color:var(--sidebar-text);cursor:pointer;transition:all var(--transition-fast);justify-content:space-between;align-items:center;margin-bottom:2px;padding:10px 16px;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.menu-item-row:hover{background-color:var(--sidebar-hover-bg);color:#fff}.menu-item-row.active{background-color:var(--sidebar-active-bg);color:#fff}.menu-item-row.active:hover{background-color:var(--sidebar-active-hover-bg);color:#fff}.menu-item-content{align-items:center;gap:12px;display:flex}.menu-item-icon{opacity:.7;width:18px;height:18px}.menu-item-row.active .menu-item-icon{opacity:1}.menu-sub-list{border-left:1px dashed var(--sidebar-border);margin-bottom:4px;margin-left:10px;padding-left:8px}.menu-sub-list .menu-item-row{padding:6px 10px;font-size:.85rem}.menu-sub-list .menu-item-icon{width:15px;height:15px}.main-content{min-height:100vh;transition:margin-left var(--transition-normal);flex-direction:column;flex:1;width:100%;min-width:0;margin-left:300px;display:flex}.navbar{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:90;justify-content:space-between;align-items:center;height:70px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-left{align-items:center;gap:16px;display:flex}.menu-toggle-btn{color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:flex}.menu-toggle-btn:hover{background-color:var(--border-color)}.quick-search-box{width:260px;position:relative}.quick-search-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--input-bg);width:100%;color:var(--text-primary);font-family:var(--font-family);transition:all var(--transition-fast);padding:8px 12px 8px 36px;font-size:.875rem}.quick-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb), .15);background-color:var(--bg-secondary);outline:none}.quick-search-icon{width:16px;height:16px;color:var(--text-secondary);opacity:.7;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.navbar-right{align-items:center;gap:16px;display:flex}.icon-action-btn{color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;display:flex}.icon-action-btn:hover{background-color:rgba(var(--color-primary-rgb), .06);color:var(--color-primary)}.user-profile-badge{border-radius:var(--radius-lg);background-color:rgba(var(--color-primary-rgb), .05);border:1px solid rgba(var(--color-primary-rgb), .1);align-items:center;gap:10px;padding:6px 12px;display:flex}.user-avatar{background-color:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:700;display:flex}.user-details{flex-direction:column;display:flex}.user-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.user-role{color:var(--text-secondary);font-size:.7rem;font-weight:500}.page-container{flex:1;width:100%;min-width:0;padding:24px}.login-screen{background:radial-gradient(circle at top right, rgba(var(--color-primary-rgb), .12), transparent 45%), radial-gradient(circle at bottom left, rgba(var(--color-accent-rgb,212, 175, 55), .05), transparent 45%), var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{border-radius:var(--radius-lg);width:100%;max-width:440px}.login-logo-container{justify-content:center;margin-bottom:28px;display:flex}.login-logo{object-fit:contain;max-width:100%;max-height:70px}.login-title{text-align:center;color:var(--text-primary);margin-bottom:8px;font-size:1.6rem;font-weight:700}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:30px;font-size:.9rem}.form-group{margin-bottom:20px;position:relative}.form-label{color:var(--text-primary);margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.input-with-icon{position:relative}.input-icon{width:18px;height:18px;color:var(--text-secondary);opacity:.6;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.form-input{border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--input-bg);width:100%;color:var(--text-primary);font-family:var(--font-family);transition:all var(--transition-fast);padding:12px 14px 12px 42px;font-size:.95rem}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb), .15);background-color:var(--bg-secondary);outline:none}.btn-primary{border-radius:var(--radius-md);background-color:var(--color-primary);color:#fff;width:100%;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:.95rem;font-weight:600;display:flex}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:0 4px 12px rgba(var(--color-primary-rgb), .2);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.alert-box{border-radius:var(--radius-sm);align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:.85rem;font-weight:500;display:flex}.alert-danger{color:var(--color-danger);background-color:#ef44441a;border:1px solid #ef444433}.sidebar-backdrop{z-index:90;background-color:#00000080;width:100vw;height:100vh;display:none;position:fixed;top:0;left:0}.mobile-close-btn{display:none}@media (width<=992px){.sidebar-backdrop{display:block}.mobile-close-btn{display:flex}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0!important}.navbar-left{gap:8px}.quick-search-box{width:160px}}@media (width<=576px){.quick-search-box,.user-details{display:none}.navbar{padding:0 16px}}.dashboard-loading{min-height:350px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner-icon{color:var(--color-primary);width:40px;height:40px;animation:1.5s linear infinite spin}.dashboard-error-panel{text-align:center;border-left:4px solid var(--color-danger);flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.dashboard-header-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.dashboard-main-title{color:var(--text-primary);letter-spacing:-.025em;margin-bottom:4px;font-size:1.8rem;font-weight:700}.dashboard-subtitle{color:var(--text-secondary);font-size:.9rem}.dashboard-controls{align-items:center;gap:12px;display:flex}.year-selector-wrapper{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:8px;padding:6px 12px;display:flex}.calendar-icon{color:var(--text-secondary)}.year-select-dropdown{color:var(--text-primary);font-family:var(--font-family);cursor:pointer;background:0 0;border:none;outline:none;padding-right:4px;font-size:.9rem;font-weight:600}.refresh-btn{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;width:38px;height:38px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.refresh-btn:hover{background-color:var(--border-color);color:var(--color-primary)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:24px;display:grid}.kpi-card{border-radius:var(--radius-md);transition:all var(--transition-normal);padding:20px;position:relative;overflow:hidden}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.kpi-card:after{content:"";width:100%;height:4px;position:absolute;top:0;left:0}.card-facturado:after{background:#3b82f6}.card-cotizado:after{background:#d4af37}.card-cobrado:after{background:#10b981}.card-egresos:after{background:#f97316}.kpi-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.kpi-card-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.85rem;font-weight:600}.kpi-icon-badge{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.color-facturado{color:#3b82f6;background-color:#3b82f626}.color-cotizado{color:#d4af37;background-color:#d4af3726}.color-cobrado{color:#10b981;background-color:#10b98126}.color-egresos{color:#f97316;background-color:#f9731626}.kpi-card-value{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:12px;font-size:1.6rem;font-weight:750}.kpi-card-footer{justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.kpi-indicator{align-items:center;gap:4px;font-weight:600;display:flex}.kpi-indicator.green{color:#10b981}.kpi-indicator.blue{color:#3b82f6}.kpi-indicator.orange{color:#f97316}.kpi-footer-detail{color:var(--text-secondary);opacity:.8}.dashboard-middle-row{grid-template-columns:1.2fr 1fr;gap:20px;margin-bottom:24px;display:grid}.cashflow-analysis-card,.conversion-rates-card{border-radius:var(--radius-md);flex-direction:column;padding:24px;display:flex}.section-card-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:20px;font-size:1.1rem;font-weight:700;display:flex;position:relative}.cashflow-totals-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.cashflow-stat{flex:1}.cashflow-stat-label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;display:block}.cashflow-stat-value{font-size:1.35rem;font-weight:700}.text-green{color:#10b981}.text-orange{color:#f97316}.cashflow-divider{background-color:var(--border-color);width:1px;height:40px;margin:0 24px}.cashflow-net-badge-container{margin-bottom:20px}.cashflow-net-badge{border-radius:var(--radius-md);align-items:center;gap:16px;padding:16px;display:flex}.cashflow-net-badge.positive{background-color:#10b98114;border:1px solid #10b98133}.cashflow-net-badge.positive .net-badge-icon{color:#10b981;background-color:#10b98126}.cashflow-net-badge.negative{background-color:#ef444414;border:1px solid #ef444433}.cashflow-net-badge.negative .net-badge-icon{color:#ef4444;background-color:#ef444426}.net-badge-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.net-badge-label{color:var(--text-secondary);font-size:.8rem;display:block}.net-badge-value{margin:2px 0;font-size:1.4rem;font-weight:800}.net-badge-status{font-size:.75rem;font-weight:600}.cashflow-bar-container{margin-top:auto}.cashflow-bar-labels{color:var(--text-secondary);justify-content:space-between;margin-bottom:6px;font-size:.8rem;display:flex}.cashflow-progress-bar-bg{background-color:var(--border-color);border-radius:4px;width:100%;height:8px;overflow:hidden}.cashflow-progress-bar-fill{border-radius:4px;height:100%;transition:width 1s ease-in-out}.cashflow-progress-bar-fill.safe{background-color:#10b981}.cashflow-progress-bar-fill.danger{background-color:#ef4444}.performance-metric-item{margin-bottom:16px}.metric-item-info{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.metric-title{color:var(--text-primary);font-size:.9rem;font-weight:600;display:block}.metric-desc{color:var(--text-secondary);font-size:.75rem}.metric-percentage-badge{border-radius:10px;padding:2px 8px;font-size:.85rem;font-weight:700}.metric-progress-bg{background-color:var(--border-color);border-radius:3px;width:100%;height:6px;overflow:hidden}.metric-progress-fill{border-radius:3px;height:100%;transition:width 1s ease-in-out}.color-cotizado-bg{background-color:#d4af37}.color-cobrado-bg{background-color:#10b981}.dashboard-quick-stats{grid-template-columns:1fr 1fr;gap:12px;margin-top:auto;padding-top:16px;display:grid}.quick-stat-box{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);text-align:center;padding:12px}.quick-stat-num{color:var(--color-primary);font-size:1.4rem;font-weight:700;display:block}.quick-stat-text{color:var(--text-secondary);font-size:.75rem}.dashboard-grid-layout{grid-template-columns:1.3fr 1fr;gap:20px;display:grid}.chart-card,.recent-activity-card{border-radius:var(--radius-md);flex-direction:column;padding:24px;display:flex}.chart-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.chart-legend{flex-wrap:wrap;gap:12px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.75rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.legend-dot.color-facturado{background-color:#3b82f6}.legend-dot.color-cotizado{background-color:#d4af37}.legend-dot.color-cobrado{background-color:#10b981}.legend-dot.color-egresos{background-color:#f97316}.chart-canvas-wrapper{width:100%;height:240px;position:relative}.svg-dashboard-chart{overflow:visible}.chart-line-stroke{stroke-dasharray:1000;stroke-dashoffset:1000px;animation:2s cubic-bezier(.25,1,.5,1) forwards drawLine}.chart-node-circle{opacity:0;transform-origin:50%;cursor:pointer;transition:all .2s;animation:.5s ease-out 1.5s forwards showNodes;transform:scale(.3)}.chart-node-circle:hover{stroke-width:2px;transform:scale(1.6)}@keyframes drawLine{to{stroke-dashoffset:0}}@keyframes showNodes{to{opacity:1;transform:scale(1)}}.activity-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.activity-pulse-dot{background-color:#10b981;border-radius:50%;width:10px;height:10px;animation:1.8s infinite pulse;box-shadow:0 0 #10b98166}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.activity-list-container{flex-direction:column;gap:12px;max-height:250px;display:flex;overflow-y:auto}.empty-activity{text-align:center;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.empty-activity-icon{opacity:.3;margin-bottom:12px}.activity-row-item{border-radius:var(--radius-sm);background-color:var(--bg-secondary);border:1px solid var(--border-color);transition:all var(--transition-fast);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.activity-row-item:hover{border-color:var(--color-primary);background-color:rgba(var(--color-primary-rgb), .03);transform:translate(4px)}.activity-row-left{align-items:center;gap:12px;display:flex}.activity-type-indicator{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;display:flex}.activity-type-indicator.factura{color:#3b82f6;background-color:#3b82f61f}.activity-type-indicator.cotización{color:#d4af37;background-color:#d4af371f}.activity-details{flex-direction:column;gap:2px;display:flex}.activity-id-row{align-items:center;gap:8px;display:flex}.activity-id{color:var(--text-primary);font-size:.85rem;font-weight:700}.activity-badge{text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:.7rem;font-weight:700}.activity-badge.emitida{color:#10b981;background-color:#10b9811f}.activity-badge.cancelada{color:#ef4444;background-color:#ef44441f}.activity-badge.facturada{color:#3b82f6;background-color:#3b82f61f}.activity-badge.borrador{color:#6b7280;background-color:#6b72801f}.activity-client{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:.78rem;overflow:hidden}.activity-row-right{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.activity-amount{color:var(--text-primary);font-size:.9rem;font-weight:750}.activity-date{color:var(--text-secondary);font-size:.75rem}@media (width<=1024px){.dashboard-middle-row,.dashboard-grid-layout{grid-template-columns:1fr}}@media (width<=768px){.dashboard-header-bar{flex-direction:column;align-items:flex-start}.dashboard-controls{justify-content:space-between;width:100%}}
