.exchange-rate-modal{max-width:500px}.exchange-rate-preview{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;padding:1rem;margin-top:1rem}.exchange-rate-preview strong{display:block;margin-bottom:.5rem;color:var(--color-text-secondary);font-size:.875rem}.preview-text{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);font-family:Courier New,monospace}.main-layout{min-height:100vh;display:flex;flex-direction:column}.header{background-color:#fff;border-bottom:3px solid var(--color-primary);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:var(--z-sticky)}.header-content{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);max-width:1400px;margin:0 auto}.header-logo{display:flex;align-items:center;gap:var(--spacing-lg)}.logo{height:50px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.header-text{display:flex;flex-direction:column;gap:.25rem}.header-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);letter-spacing:-.5px}.header-subtitle{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.header-user{display:flex;align-items:center;gap:var(--spacing-md)}.user-name{font-weight:var(--font-weight-semibold);color:var(--color-text)}.user-role{font-size:var(--font-size-sm);color:#fff;text-transform:uppercase;padding:var(--spacing-xs) var(--spacing-md);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);letter-spacing:.5px;box-shadow:var(--shadow-sm)}.layout-body{display:flex;flex:1;width:100%}.sidebar{width:260px;min-width:260px;flex-shrink:0;background:linear-gradient(180deg,var(--color-sidebar-bg) 0%,#263849 100%);border-right:none;padding:var(--spacing-xl) 0;box-shadow:var(--shadow-lg)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:0 var(--spacing-md)}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);color:var(--color-sidebar-text-secondary);font-weight:var(--font-weight-medium);transition:all var(--transition-base);border-radius:var(--radius-md);border-left:3px solid transparent;position:relative;overflow:hidden}.sidebar-link:hover{background-color:var(--color-sidebar-hover);color:var(--color-sidebar-text);transform:translate(4px);box-shadow:var(--shadow-sm)}.sidebar-link.active{background:var(--color-sidebar-active);color:#fff;font-weight:var(--font-weight-semibold);box-shadow:inset 0 0 0 1px #ffffff1a}.sidebar-link.active:before{transform:scaleY(1)}.sidebar-icon{font-size:1.4rem;transition:all var(--transition-base)}.sidebar-link:hover .sidebar-icon,.sidebar-link.active .sidebar-icon{color:var(--color-primary-light);transform:scale(1.1)}.sidebar-section{margin:0}.sidebar-dropdown{width:100%;background:none;border:none;cursor:pointer;text-align:left;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);color:var(--color-sidebar-text-secondary);font-weight:var(--font-weight-medium);transition:all var(--transition-base);border-radius:var(--radius-md);position:relative;overflow:hidden}.sidebar-dropdown:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--color-primary);transform:scaleY(0);transition:transform var(--transition-base)}.sidebar-dropdown span{flex:1}.sidebar-dropdown svg:last-child{margin-left:auto;transition:transform var(--transition-base)}.sidebar-dropdown:hover{background-color:var(--color-sidebar-hover);color:var(--color-sidebar-text);transform:translate(4px)}.sidebar-dropdown:hover:before{transform:scaleY(1)}.sidebar-dropdown:hover svg:last-child{color:var(--color-primary-light)}.sidebar-submenu{display:flex;flex-direction:column;background:#0003;border-radius:var(--radius-md);margin:var(--spacing-xs) 0 var(--spacing-xs) var(--spacing-lg);padding:var(--spacing-xs);border-left:2px solid var(--color-primary)}.sidebar-divider{height:1px;background:#ffffff1a;margin:var(--spacing-md) var(--spacing-md)}.sidebar-section-title{padding:var(--spacing-md);color:var(--color-sidebar-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.sidebar-sublink{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-sidebar-text-secondary);font-weight:var(--font-weight-normal);font-size:var(--font-size-sm);transition:all var(--transition-fast);border-radius:var(--radius-sm);position:relative;padding-left:calc(var(--spacing-md) + 8px)}.sidebar-sublink:before{content:"•";position:absolute;left:var(--spacing-sm);color:var(--color-primary-light);opacity:0;transition:opacity var(--transition-fast)}.sidebar-sublink:hover{background-color:var(--color-sidebar-hover);color:var(--color-sidebar-text);padding-left:calc(var(--spacing-md) + 12px)}.sidebar-sublink:hover:before{opacity:1}.main-content{flex:1;padding:var(--spacing-xl);background:linear-gradient(135deg,#f8f9fa,#e9ecef);min-height:calc(100vh - 86px)}.currency-controls{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.exchange-rate-display{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background-color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-base);border:1px solid transparent}.exchange-rate-display.clickable:hover{background:linear-gradient(135deg,#fff5f5,#ffe8e8);border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.exchange-rate-display .rate-label{color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}.exchange-rate-display .rate-value{color:var(--color-text);font-weight:var(--font-weight-bold);font-family:var(--font-family-mono)}.exchange-rate-display .edit-icon{font-size:.875rem;color:var(--color-primary);opacity:.6;transition:all var(--transition-fast)}.exchange-rate-display.clickable:hover .edit-icon{opacity:1;transform:rotate(90deg)}@media (max-width: 768px){.layout-body{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:2px solid var(--color-primary);padding:var(--spacing-md) 0}.sidebar-nav{flex-direction:row;overflow-x:auto;padding:0 var(--spacing-sm)}.sidebar-link,.sidebar-dropdown{white-space:nowrap}.header-content{padding:var(--spacing-md)}.header-logo{gap:var(--spacing-md)}.logo{height:40px}.header-title{font-size:var(--font-size-lg)}.header-subtitle{font-size:var(--font-size-xs)}.header-user{flex-direction:column;align-items:flex-end;gap:var(--spacing-xs)}.user-name{display:none}}.exchange-rate-modal{max-width:500px;width:100%}.rate-input-container{position:relative;display:flex;align-items:center;gap:8px}.currency-prefix,.currency-suffix{font-size:1.1rem;color:#666;font-weight:500}.rate-input-container input{flex:1;font-size:1.5rem;text-align:center;font-weight:600;padding:12px;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .3s}.rate-input-container input:focus{border-color:#2ecc71;outline:none}.exchange-info{margin-top:16px;padding:12px;background:#f8f9fa;border-left:3px solid #2ecc71;border-radius:4px}.exchange-info p{margin:0;font-size:.9rem;color:#555;line-height:1.5}.error-message{padding:10px;background:#fee;border-left:3px solid #f44;border-radius:4px;color:#c00;margin-top:12px;font-size:.9rem}.form-hint{display:block;margin-top:8px;color:#666;font-size:.85rem;text-align:center;font-weight:500}:root{--color-primary: #2ecc71;--color-primary-light: #58d68d;--color-primary-dark: #27ae60;--color-background: #f5f7fa;--color-sidebar-bg: #2c3e50;--color-sidebar-hover: #34495e;--color-sidebar-text: #ecf0f1;--color-sidebar-text-secondary: #bdc3c7;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-weight-normal: 400;--font-weight-semibold: 600;--font-weight-bold: 700;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--transition-fast: .15s ease;--transition-base: .3s ease}.main-layout{display:flex;flex-direction:column;height:100vh;background-color:var(--color-background)}.header{background:#fff;box-shadow:0 2px 8px #0000001a;padding:0 var(--spacing-xl);z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;height:70px;max-width:1800px;margin:0 auto}.header-logo{display:flex;align-items:center;gap:var(--spacing-md)}.logo{height:45px;width:auto}.header-text{display:flex;flex-direction:column}.header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:#2ecc71}.header-subtitle{font-size:var(--font-size-xs);color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.header-user{display:flex;align-items:center;gap:var(--spacing-lg)}.user-name{font-weight:var(--font-weight-semibold);color:#2c3e50}.user-role{font-size:var(--font-size-sm);color:#95a5a6;text-transform:capitalize}.button{padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:var(--spacing-sm)}.layout-body{display:flex;flex:1;overflow:hidden}.sidebar{width:260px;background-color:var(--color-sidebar-bg);display:flex;flex-direction:column;overflow-y:auto;box-shadow:2px 0 8px #0000001a}.sidebar-nav{display:flex;flex-direction:column;padding:var(--spacing-md);gap:var(--spacing-xs)}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);color:var(--color-sidebar-text);text-decoration:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);transition:all var(--transition-base);position:relative}.sidebar-link:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--color-primary);transform:scaleY(0);transition:transform var(--transition-base)}.sidebar-link:hover{background-color:var(--color-sidebar-hover);transform:translate(4px)}.sidebar-link:hover:before{transform:scaleY(1)}.sidebar-icon{font-size:1.25rem;color:var(--color-primary-light)}.main-content{flex:1;overflow-y:auto;padding:var(--spacing-xl);background-color:var(--color-background)}.exchange-rate-display{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;font-family:Courier New,monospace;transition:all .3s ease;position:relative}.exchange-rate-display.clickable{cursor:pointer}.exchange-rate-display.clickable:hover{background:linear-gradient(135deg,#2ecc71,#27ae60);border-color:#2ecc71;transform:translateY(-1px);box-shadow:0 4px 12px #2ecc7133}.exchange-rate-display.clickable:hover .rate-label,.exchange-rate-display.clickable:hover .rate-value{color:#fff}.exchange-rate-display.clickable:hover .edit-icon{opacity:1;transform:rotate(90deg);color:#fff}.rate-label{font-size:.85rem;color:#7f8c8d;font-weight:600;transition:color .3s ease}.rate-value{font-size:1rem;color:#2c3e50;font-weight:700;transition:color .3s ease}.edit-icon{font-size:1rem;color:#95a5a6;opacity:0;transition:all .3s ease}:root{--config-color-primary: #9b59b6;--config-color-primary-light: #bb8fce;--config-color-primary-dark: #7d3c98;--config-color-background: #f5f7fa;--config-color-sidebar-bg: #34495e;--config-color-sidebar-hover: #415b76;--config-color-sidebar-text: #ecf0f1;--config-color-sidebar-text-secondary: #bdc3c7;--config-spacing-xs: .25rem;--config-spacing-sm: .5rem;--config-spacing-md: 1rem;--config-spacing-lg: 1.5rem;--config-spacing-xl: 2rem;--config-font-size-xs: .75rem;--config-font-size-sm: .875rem;--config-font-size-md: 1rem;--config-font-size-lg: 1.125rem;--config-font-weight-normal: 400;--config-font-weight-semibold: 600;--config-font-weight-bold: 700;--config-radius-sm: .25rem;--config-radius-md: .5rem;--config-radius-lg: 1rem;--config-transition-fast: .15s ease;--config-transition-base: .3s ease}.config-layout{display:flex;flex-direction:column;height:100vh;background-color:var(--config-color-background)}.config-header{background:#fff;box-shadow:0 2px 8px #0000001a;z-index:100;width:100%}.config-header-content{display:flex;justify-content:space-between;align-items:center;height:70px;width:100%;padding:0 var(--config-spacing-xl);box-sizing:border-box}.config-header-logo{display:flex;align-items:center;gap:var(--config-spacing-md)}.config-logo{height:45px;width:auto}.config-header-text{display:flex;flex-direction:column}.config-header-title{font-size:var(--config-font-size-lg);font-weight:var(--config-font-weight-bold);color:var(--config-color-primary)}.config-header-subtitle{font-size:var(--config-font-size-xs);color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.config-header-user{display:flex;align-items:center;gap:var(--config-spacing-lg)}.config-user-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.config-user-name{font-weight:var(--config-font-weight-semibold);color:#2c3e50;font-size:var(--config-font-size-md);line-height:1.2}.config-user-role{font-size:var(--config-font-size-xs);color:#95a5a6;text-transform:capitalize;line-height:1.2}.config-button{padding:var(--config-spacing-sm) var(--config-spacing-md);border:none;border-radius:var(--config-radius-md);font-weight:var(--config-font-weight-semibold);cursor:pointer;transition:all var(--config-transition-base);display:flex;align-items:center;gap:var(--config-spacing-sm)}.config-button-ghost{background:transparent;color:#7f8c8d}.config-button-ghost:hover{background:#ecf0f1;color:#2c3e50}.config-button-sm{padding:var(--config-spacing-xs) var(--config-spacing-md);font-size:var(--config-font-size-sm)}.config-layout-body{display:flex;flex:1;overflow:hidden}.config-sidebar{width:260px;background-color:var(--config-color-sidebar-bg);display:flex;flex-direction:column;overflow-y:auto;box-shadow:2px 0 8px #0000001a}.config-sidebar-nav{display:flex;flex-direction:column;padding:var(--config-spacing-md);gap:var(--config-spacing-xs)}.config-sidebar-link{display:flex;align-items:center;gap:var(--config-spacing-md);padding:var(--config-spacing-md);color:var(--config-color-sidebar-text);text-decoration:none;border-radius:var(--config-radius-md);font-weight:var(--config-font-weight-semibold);transition:all var(--config-transition-base);position:relative}.config-sidebar-link:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--config-color-primary);transform:scaleY(0);transition:transform var(--config-transition-base)}.config-sidebar-link:hover{background-color:var(--config-color-sidebar-hover);transform:translate(4px)}.config-sidebar-link:hover:before{transform:scaleY(1)}.config-sidebar-icon{font-size:1.25rem;color:var(--config-color-primary-light)}.config-sidebar-divider{height:1px;background:#ffffff1a;margin:var(--config-spacing-md) 0}.config-main-content{flex:1;overflow-y:auto;padding:var(--config-spacing-xl);background-color:var(--config-color-background)}@media (max-width: 768px){.config-sidebar{width:200px}.config-header-content{padding:0 var(--config-spacing-md)}.config-main-content{padding:var(--config-spacing-md)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);padding:var(--spacing-xl)}.login-container{width:100%;max-width:400px;background-color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-2xl)}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.login-logo{height:80px;width:auto;margin-bottom:var(--spacing-lg)}.login-header h1{font-size:var(--font-size-2xl);color:var(--color-text);margin-bottom:var(--spacing-sm)}.login-header p{color:var(--color-text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column}.login-error{padding:var(--spacing-md);background-color:#fee;border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);text-align:center}.login-footer{margin-top:var(--spacing-xl);text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.module-selector{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;position:relative}.module-selector-header{position:absolute;top:0;left:0;right:0;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.module-user-info{display:flex;flex-direction:column;color:#fff}.module-user-name{font-weight:600;font-size:.95rem}.module-user-role{font-size:.8rem;opacity:.8;text-transform:capitalize}.module-header-actions{display:flex;gap:.5rem}.module-settings-btn,.module-logout-btn{background:#ffffff40;border:2px solid rgba(255,255,255,.4);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1.3rem;text-decoration:none;padding:0}.module-settings-btn svg,.module-logout-btn svg{width:22px;height:22px;display:block}.module-settings-btn:hover,.module-logout-btn:hover{background:#ffffff4d;transform:scale(1.1)}.module-hero{text-align:center;margin-bottom:3rem;color:#fff}.module-logo{width:150px;height:auto;margin-bottom:1.5rem;filter:drop-shadow(0 4px 6px rgba(0,0,0,.2))}.module-hero h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.1)}.module-subtitle{font-size:1.1rem;opacity:.9}.modules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:900px;width:100%}.module-card{background:#fff;border-radius:16px;padding:2.5rem;text-align:center;text-decoration:none;color:#333;transition:all .3s ease;box-shadow:0 10px 30px #00000026;position:relative;overflow:hidden}.module-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--module-color);transform:scaleX(0);transition:transform .3s ease}.module-card:hover:before{transform:scaleX(1)}.module-card:hover{transform:translateY(-8px);box-shadow:0 15px 40px #0003}.module-icon{font-size:4rem;color:var(--module-color);margin-bottom:1rem;transition:transform .3s ease}.module-card:hover .module-icon{transform:scale(1.1)}.module-card h3{font-size:1.5rem;font-weight:600;margin-bottom:.75rem;color:#222}.module-card p{font-size:.95rem;color:#666;line-height:1.5}@media (max-width: 768px){.module-hero h1{font-size:2rem}.modules-grid{grid-template-columns:1fr;max-width:400px}.module-card{padding:2rem}}.global-settings{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.global-settings-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:3rem;color:#fff}.back-button{background:#fff3;border:none;color:#fff;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1.5rem;text-decoration:none}.back-button:hover{background:#ffffff4d;transform:scale(1.1)}.global-settings-header h1{font-size:2.5rem;font-weight:700;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.1)}.settings-subtitle{font-size:1.1rem;opacity:.9;margin:.5rem 0 0}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.settings-card{background:#fff;border-radius:16px;padding:2.5rem;text-align:center;text-decoration:none;color:#333;transition:all .3s ease;box-shadow:0 10px 30px #00000026;position:relative;overflow:hidden}.settings-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--settings-color);transform:scaleX(0);transition:transform .3s ease}.settings-card:hover:before{transform:scaleX(1)}.settings-card:hover{transform:translateY(-8px);box-shadow:0 15px 40px #0003}.settings-icon{font-size:4rem;color:var(--settings-color);margin-bottom:1rem;transition:transform .3s ease}.settings-card:hover .settings-icon{transform:scale(1.1)}.settings-card h3{font-size:1.5rem;font-weight:600;margin-bottom:.75rem;color:#222}.settings-card p{font-size:.95rem;color:#666;line-height:1.5}@media (max-width: 768px){.global-settings-header h1{font-size:2rem}.settings-grid{grid-template-columns:1fr;max-width:400px}.settings-card{padding:2rem}}.home-page{max-width:1200px;margin:0 auto}.home-hero{text-align:center;padding:var(--spacing-2xl) 0;margin-bottom:var(--spacing-xl)}.home-logo{height:100px;width:auto;margin-bottom:var(--spacing-lg)}.home-hero h1{font-size:var(--font-size-4xl);color:var(--color-text);margin-bottom:var(--spacing-md)}.home-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);max-width:600px;margin:0 auto}.dashboards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.dashboard-card{background-color:#fff;padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base);text-align:center;border-top:4px solid var(--card-color, var(--color-primary))}.dashboard-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.dashboard-icon{font-size:3rem;color:var(--card-color, var(--color-primary));margin-bottom:var(--spacing-md)}.dashboard-card h3{font-size:var(--font-size-xl);color:var(--color-text);margin-bottom:var(--spacing-sm)}.dashboard-card p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.dashboard-page{max-width:1200px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.dashboard-page h1{font-size:var(--font-size-4xl);color:var(--color-text);margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-bold);letter-spacing:-.5px}.dashboard-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-lg);margin-bottom:0}.kpis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.dashboard-section{background-color:#fff;padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl);border:1px solid var(--color-border-light);transition:all var(--transition-base)}.dashboard-section:hover{box-shadow:var(--shadow-lg)}.dashboard-section h2{font-size:var(--font-size-2xl);color:var(--color-text);margin-bottom:var(--spacing-lg)}.filters-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-xl);border-bottom:2px solid var(--color-border)}.tab{background:none;border:none;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;position:relative;transition:var(--transition-fast)}.tab:hover{color:var(--color-text);background:var(--color-bg-secondary)}.tab.active{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--color-primary)}.report-builder{display:flex;flex-direction:column;gap:var(--spacing-xl)}.report-section{padding:var(--spacing-lg);background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.report-section h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-md)}.connections-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.checkbox-label:hover{background:var(--color-bg-hover);border-color:var(--color-primary)}.checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.checkbox-label span{font-size:var(--font-size-sm);color:var(--color-text)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.filters-grid label{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.filters-grid input,.filters-grid select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text);background-color:var(--color-bg);transition:var(--transition-fast)}.filters-grid input:focus,.filters-grid select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #cc33341a}.column-selector-actions{display:flex;gap:var(--spacing-sm);align-items:center;margin-bottom:var(--spacing-md);flex-wrap:wrap}.columns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-sm)}.report-summary{background:var(--color-bg);padding:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}.report-summary p{margin:var(--spacing-xs) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.alert-warning ul{margin:var(--spacing-sm) 0 0 var(--spacing-lg);list-style:disc}.alert-warning li{margin:var(--spacing-xs) 0}.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl)}.loader-spinner{border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loader-small .loader-spinner{width:20px;height:20px;border-width:2px}.loader-medium .loader-spinner{width:40px;height:40px}.loader-large .loader-spinner{width:60px;height:60px;border-width:4px}.loader-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.error-message{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background-color:#fee;border:1px solid var(--color-error);border-radius:var(--radius-md);text-align:center}.error-icon{font-size:3rem;color:var(--color-error)}.error-text{color:var(--color-text);margin:0}.recetas-container{display:grid;grid-template-columns:350px 1fr;gap:1.5rem;height:calc(100vh - 200px)}.recetas-sidebar{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;overflow-y:auto}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.sidebar-header h3{margin:0;font-size:1.1rem;color:#333}.recetas-sidebar h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.rubros-list{display:flex;flex-direction:column;gap:1rem}.rubro-item{border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.rubro-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f5f5f5;border-bottom:1px solid #e0e0e0;font-size:.95rem}.rubro-header .badge{background:#2196f3;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.recetas-list{display:flex;flex-direction:column}.receta-item{padding:.75rem 1rem;cursor:pointer;transition:all .2s;border-bottom:1px solid #f0f0f0;font-size:.9rem}.receta-item:last-child{border-bottom:none}.receta-item:hover{background:#f9f9f9;padding-left:1.25rem}.receta-item.active{background:#e3f2fd;color:#1976d2;font-weight:600;border-left:3px solid #2196f3}.recetas-detail{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;overflow-y:auto}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:1rem}.receta-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:1.5rem;border-bottom:2px solid #e0e0e0;margin-bottom:1.5rem}.receta-detail-header h2{margin:0 0 .5rem;font-size:1.5rem;color:#333}.receta-cost{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.receta-cost .label{font-size:.85rem;color:#666;font-weight:500}.receta-cost .value{font-size:1.75rem;font-weight:700;color:#2196f3}.receta-items-section{margin-top:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h3{margin:0;font-size:1.1rem;color:#333}.add-receta-form{background:#f0f8ff;border:2px dashed #2196f3;border-radius:6px;padding:1rem;margin-bottom:1rem}.add-item-form{background:#f9f9f9;border:2px dashed #ddd;border-radius:6px;padding:1.5rem;margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr 2fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;font-weight:600;color:#555}.form-group input,.form-group select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.form-actions{display:flex;gap:.75rem;justify-content:flex-end}.items-table{width:100%;border-collapse:collapse;margin-top:1rem;table-layout:fixed}.items-table thead th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #e0e0e0;background:#f5f5f5;font-size:.9rem}.items-table thead th:nth-child(1){width:20%}.items-table thead th:nth-child(2){width:10%}.items-table thead th:nth-child(3){width:15%}.items-table thead th:nth-child(4){width:15%}.items-table thead th:nth-child(5){width:30%}.items-table thead th:nth-child(6){width:10%}.items-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .2s}.items-table tbody tr:hover{background:#f9f9f9}.items-table td{padding:1rem;font-size:.9rem;vertical-align:top}.items-table td:nth-child(5){padding:1rem 1.25rem}.item-name{font-weight:500;color:#333}.item-calculo{font-size:.85rem;color:#666;font-style:italic;word-wrap:break-word;line-height:1.4;display:block;max-width:100%}.item-notes{font-size:.8rem;color:#666;font-style:italic;margin-top:.25rem}.items-table tfoot tr{border-top:2px solid #333;background:#f5f5f5}.items-table tfoot td{padding:1rem;font-size:1rem}.button-icon{background:none;border:none;cursor:pointer;padding:.5rem;color:#666;transition:all .2s;border-radius:4px;display:inline-flex;align-items:center;justify-content:center}.button-icon:hover{background:#f0f0f0;color:#333}.button-icon.button-danger:hover{background:#ffebee;color:#d32f2f}.button-sm{padding:.5rem 1rem;font-size:.875rem}.editing-row{background:#fffbf0!important}.edit-input,.edit-input-notes,.edit-input-small{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;width:100%}.edit-input{margin-bottom:.5rem}.edit-input-notes{font-size:.8rem;font-style:italic}.edit-input-small{width:100px;text-align:right}.edit-select-currency{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;width:70px}.edit-select-tramo{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;width:100%;min-width:300px;background:#fff}.button-icon.button-success:hover{background:#e8f5e9;color:#2e7d32}.converted-amount{font-size:.8rem;color:#666;font-style:italic;margin-top:.25rem}.item-name-container{display:flex;align-items:center;gap:.5rem}.formula-info-icon{display:inline-flex;align-items:center;justify-content:center;color:#2196f3;font-size:1.1rem;cursor:help;transition:color .2s}.formula-info-icon:hover{color:#1976d2}.formula-info-icon[title]{position:relative}@media (max-width: 1024px){.recetas-container{grid-template-columns:1fr;height:auto}.recetas-sidebar{max-height:400px}.form-row{grid-template-columns:1fr}}.consolidado-kpis{display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;background:#fff;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:1rem;font-size:.875rem;color:#666;flex-wrap:wrap}.kpi-item{display:inline-flex;align-items:center;gap:.25rem}.kpi-item strong{color:#1a1a1a;font-weight:600}.kpi-item.kpi-ventas strong{color:#059669}.kpi-item.kpi-costos strong{color:#d97706}.kpi-separator{color:#ddd;font-weight:300}.button-sm{padding:.5rem 1rem;font-size:.875rem;margin-left:auto}.consolidado-wrapper{overflow:visible!important;height:auto!important;contain:none!important;position:relative}.consolidado-wrapper .dashboard-section{padding:0!important;overflow:visible!important;background:transparent!important;box-shadow:none!important;contain:none!important;position:static}.consolidado-table-container{width:100%;height:calc(100vh - 280px);min-height:600px;border-radius:8px;border:1px solid #e0e0e0;background:#fff;overflow:auto;position:relative}.consolidado-table-container.maximized{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw!important;height:100vh!important;max-height:100vh!important;z-index:9999;border-radius:0;margin:0;min-height:auto}.maximize-button{position:sticky;top:0;right:0;z-index:102;float:right;margin:.5rem;padding:.5rem 1rem;background:#06c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;display:flex;align-items:center;gap:.5rem;transition:all .2s}.maximize-button:hover{background:#0052a3;transform:scale(1.05)}.consolidado-table{width:100%;border-collapse:collapse;border-spacing:0}.consolidado-table thead th{padding:.875rem 1rem;text-align:left;font-weight:700;color:#fff;border-bottom:none;border-right:1px solid rgba(255,255,255,.2);white-space:nowrap;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);vertical-align:middle;box-shadow:0 2px 6px #cc33344d;text-transform:uppercase;font-size:.8rem;letter-spacing:.5px}.consolidado-table thead th:last-child{border-right:none}.consolidado-table .first-column-cell{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border-right:3px solid var(--color-primary);font-weight:700;box-shadow:3px 0 6px #00000026;font-size:.9rem}.consolidado-table thead th.first-column-cell{background:linear-gradient(135deg,var(--color-primary-dark) 0%,#8a1f1f 100%);color:#fff;text-align:center;font-size:.85rem}.consolidado-table tbody tr:hover td.first-column-cell{background:linear-gradient(135deg,#34495e,#3d5a73);transform:translate(2px);transition:all .2s ease}.consolidado-table tfoot td.first-column-cell{background:linear-gradient(135deg,#1a252f,#2c3e50);color:#fff;font-weight:700}.th-header-content{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-width:fit-content}.th-label{flex:1;-webkit-user-select:none;user-select:none;transition:color .2s;color:#fff}.th-label:hover{color:#ffebeb;text-shadow:0 0 8px rgba(255,255,255,.5)}.filter-button{transition:all .2s;border-radius:3px;opacity:.7;color:#fff}.filter-button:hover{opacity:1;background:#fff3!important;transform:scale(1.1)}.filter-button.active{opacity:1;font-weight:700;background:#ffffff4d!important}.consolidado-table tfoot td{padding:1rem;background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border-top:3px solid var(--color-primary);border-right:1px solid rgba(255,255,255,.2);font-weight:700;font-size:.95rem;box-shadow:0 -2px 6px #00000026}.consolidado-table tfoot td:last-child{border-right:none}.consolidado-table tbody td{padding:.875rem 1rem;border-bottom:1px solid #f0f0f0;border-right:1px solid #f0f0f0;background:#fff;white-space:nowrap}.consolidado-table tbody td:last-child{border-right:none}.consolidado-table tbody tr:hover,.consolidado-table tbody tr:hover td{background-color:#f9f9f9}.consolidado-table .text-right{text-align:right}.clase-cell{position:relative;cursor:help;display:inline-block}.consolidado-table tbody tr:hover{position:relative;z-index:1000}.clase-name{border-bottom:1px dotted #999}.clase-tooltip{position:absolute;left:0;bottom:100%;margin-bottom:.5rem;background:#333;color:#fff;padding:.75rem;border-radius:6px;font-size:.875rem;line-height:1.5;white-space:nowrap;z-index:10000;opacity:0;pointer-events:none;transition:opacity .2s ease;box-shadow:0 4px 12px #0006}.clase-tooltip:before{content:"";position:absolute;top:100%;left:1rem;border:6px solid transparent;border-top-color:#333}.clase-tooltip div{margin-bottom:.25rem}.clase-tooltip div:last-child{margin-bottom:0}.clase-tooltip strong{font-weight:600;margin-right:.25rem}.clase-cell:hover .clase-tooltip{opacity:1;pointer-events:auto}.margen-bueno{background-color:#f0fdf4!important;color:#059669;font-weight:600}.margen-medio{background-color:#fffbeb!important;color:#d97706;font-weight:600}.margen-bajo{background-color:#fef2f2!important;color:#dc2626;font-weight:600}.margen-neutral{color:#666}.column-ventas{background-color:#f0fdf4!important}.column-costos{background-color:#fff7ed!important}.column-margen{font-weight:600}.consolidado-table tbody tr:hover td.column-ventas{background-color:#dcfce7!important}.consolidado-table tbody tr:hover td.column-costos{background-color:#ffedd5!important}.consolidado-table tbody tr:hover td.margen-bueno{background-color:#dcfce7!important}.consolidado-table tbody tr:hover td.margen-medio{background-color:#fef3c7!important}.consolidado-table tbody tr:hover td.margen-bajo{background-color:#fee2e2!important}.total-row{font-weight:600}.pivot-config-panel{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;padding:1.5rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px}.pivot-dropzone{min-height:80px;padding:.75rem;border:2px dashed #ddd;border-radius:6px;background:#fafafa}.pivot-dropzone label{display:block;font-size:.75rem;font-weight:600;color:#666;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.pivot-fields{display:flex;flex-direction:column;gap:.5rem}.pivot-field{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:move;font-size:.875rem;transition:all .2s}.pivot-field:hover{background:#f0f0f0;border-color:#06c;box-shadow:0 2px 4px #0000001a}.pivot-field:active{cursor:grabbing;opacity:.7}.th-content{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.filter-container{position:relative;display:inline-block;z-index:100}.filter-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:10000!important;min-width:220px;max-height:350px;overflow-y:auto}.filter-actions{display:flex;gap:.5rem;padding:.75rem;border-bottom:1px solid #eee}.filter-actions button{flex:1;padding:.5rem;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .2s}.filter-actions button:hover{background:#f0f0f0;border-color:#06c}.filter-options{padding:.5rem}.filter-option{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;border-radius:4px;font-size:.875rem;transition:background .2s}.filter-option:hover{background:#f5f5f5}.filter-option input[type=checkbox]{cursor:pointer}.filter-option span{flex:1;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.consolidado-stats{grid-template-columns:1fr}.consolidado-table th,.consolidado-table td{padding:.75rem;font-size:.875rem}.stat-value{font-size:1.5rem}.pivot-config-panel{grid-template-columns:1fr}}.filters-panel{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.filters-section{display:grid;grid-template-columns:200px 1fr;gap:2rem}.filter-group{display:flex;flex-direction:column;gap:.75rem}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.filter-header h4{margin:0;font-size:.95rem;font-weight:600;color:#333}.filter-actions{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.filter-actions span{color:#ddd}.btn-link{background:none;border:none;color:#2196f3;cursor:pointer;padding:0;font-size:.85rem;text-decoration:none;transition:color .2s}.btn-link:hover{color:#1976d2;text-decoration:underline}.filter-options{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto;padding:.5rem;background:#fff;border:1px solid #e0e0e0;border-radius:6px}.filter-options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem;max-height:300px}.filter-checkbox{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;cursor:pointer;border-radius:4px;transition:background-color .2s;-webkit-user-select:none;user-select:none}.filter-checkbox:hover{background-color:#f0f0f0}.filter-checkbox input[type=checkbox]{cursor:pointer;width:16px;height:16px}.filter-checkbox span{font-size:.875rem;color:#444}.filter-checkbox input[type=checkbox]:checked+span{font-weight:600;color:#2196f3}@media (max-width: 768px){.filters-section{grid-template-columns:1fr}.filter-options-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.comidas-filter-config-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.comidas-filter-config-panel{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;width:90%;max-width:700px;max-height:90vh;display:flex;flex-direction:column}.config-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.config-title{display:flex;align-items:center;gap:12px;color:#333}.config-title h3{margin:0;font-size:1.25rem;font-weight:600}.btn-close{background:none;border:none;cursor:pointer;padding:4px;color:#666;border-radius:4px;transition:all .2s}.btn-close:hover{background-color:#f5f5f5;color:#333}.config-body{padding:24px;overflow-y:auto;flex:1}.config-info{display:flex;gap:12px;padding:12px;background-color:#e3f2fd;border-left:4px solid #2196f3;border-radius:4px;margin-bottom:24px}.config-info p{margin:0;color:#1565c0;font-size:.9rem}.config-error{padding:12px;background-color:#ffebee;border-left:4px solid #f44336;border-radius:4px;color:#c62828;margin-bottom:20px;font-size:.9rem}.config-section{margin-bottom:28px}.config-section h4{margin:0 0 16px;color:#333;font-size:1rem;font-weight:600}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:12px}.checkbox-label{display:flex;align-items:center;gap:8px;padding:10px 12px;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.checkbox-label:hover{background-color:#f0f0f0;border-color:#2196f3}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px}.checkbox-label input[type=checkbox]:checked+span{font-weight:600;color:#2196f3}.checkbox-label span{font-size:.9rem;color:#555}.selected-count{font-size:.85rem;color:#666;font-style:italic}.config-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e0e0e0;background-color:#fafafa}.btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:#e0e0e0;color:#333}.btn-secondary:hover:not(:disabled){background-color:#d0d0d0}.btn-primary{background-color:#2196f3;color:#fff}.btn-primary:hover:not(:disabled){background-color:#1976d2;box-shadow:0 2px 8px #2196f34d}.kpi-card{background-color:#fff;padding:var(--spacing-lg);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);transition:all var(--transition-base);border:1px solid var(--color-border-light);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.kpi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--color-primary-light)}.kpi-card:hover:before{transform:scaleX(1)}.kpi-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.kpi-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0}.kpi-icon{font-size:1.5rem;color:var(--color-primary);opacity:.7}.kpi-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text);margin-bottom:var(--spacing-sm);word-break:break-word;overflow-wrap:break-word;line-height:1.2}.kpi-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.kpi-trend{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.kpi-trend-up{color:var(--color-success)}.kpi-trend-down{color:var(--color-error)}.kpi-section{margin-bottom:3rem;background:var(--bg-paper);border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.kpi-section-title{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;color:var(--text-primary);border-bottom:2px solid var(--color-primary);padding-bottom:.5rem}.kpi-section-title svg{color:var(--color-primary);font-size:1.75rem}.kpi-section-subtitle{font-size:.95rem;color:var(--text-secondary);margin-top:-1rem;margin-bottom:1.5rem;font-style:italic}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.kpi-subsection{margin-top:2rem}.kpi-subsection h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.kpi-table table{width:100%;border-collapse:collapse;background:var(--bg-default);border-radius:8px;overflow:hidden}.kpi-table thead{background:var(--color-primary);color:#fff}.kpi-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.kpi-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.kpi-table tbody tr:hover{background:var(--bg-hover)}.kpi-table tbody tr:last-child td{border-bottom:none}.rank-badge{display:inline-block;width:24px;height:24px;line-height:24px;text-align:center;background:var(--color-primary);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;margin-right:.5rem}.cost-bar-container{width:150px;height:20px;background:var(--bg-hover);border-radius:10px;overflow:hidden;display:inline-block}.cost-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:10px;transition:width .3s ease}.cost-bar.montana{background:linear-gradient(90deg,#0088fe,#00c49f)}.rentabilidad-chart{margin-top:1.5rem;padding:1.5rem;background:var(--bg-default);border-radius:8px}.rentabilidad-bar{display:flex;height:60px;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem}.rentabilidad-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9rem;transition:all .3s ease}.rentabilidad-segment.margen{background:linear-gradient(135deg,#4caf50,#66bb6a)}.rentabilidad-segment.costos{background:linear-gradient(135deg,#ff9800,#ffb74d)}.rentabilidad-segment span{text-shadow:0 1px 2px rgba(0,0,0,.2)}.rentabilidad-legend{display:flex;justify-content:center;gap:3rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.95rem}.legend-color{width:20px;height:20px;border-radius:4px;box-shadow:0 1px 3px #0003}.legend-color.margen{background:linear-gradient(135deg,#4caf50,#66bb6a)}.legend-color.costos{background:linear-gradient(135deg,#ff9800,#ffb74d)}.kpi-metadata{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border-color);text-align:center;color:var(--text-secondary);font-size:.875rem}@media (max-width: 768px){.kpi-grid{grid-template-columns:1fr}.kpi-section{padding:1rem}.kpi-section-title{font-size:1.25rem}.cost-bar-container{width:100px}.rentabilidad-bar{height:50px}.rentabilidad-segment span{font-size:.75rem}.rentabilidad-legend{flex-direction:column;gap:1rem;align-items:flex-start}.kpi-table table{font-size:.85rem}.kpi-table th,.kpi-table td{padding:.5rem}}.productos-chart-container{display:grid;grid-template-columns:1fr 300px;gap:2rem;align-items:center}.productos-table{min-width:0}.pie-chart-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.pie-chart{width:100%;max-width:250px;height:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.pie-center-text{font-size:14px;font-weight:600;fill:var(--text-primary)}.pie-legend{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.pie-legend-item{display:flex;align-items:center;gap:.5rem}.pie-legend-color{width:16px;height:16px;border-radius:3px;box-shadow:0 1px 2px #0003}.pie-legend-text{font-size:.875rem;font-weight:600;color:var(--text-secondary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.kpi-section{animation:fadeInUp .5s ease-out}.kpi-section:nth-child(2){animation-delay:.1s}.kpi-section:nth-child(3){animation-delay:.2s}.kpi-section:nth-child(4){animation-delay:.3s}@media (max-width: 992px){.productos-chart-container{grid-template-columns:1fr}.pie-chart-container{margin-top:2rem}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-header-actions{display:flex;gap:.75rem}.admin-table-container{overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background:var(--color-bg-secondary);border-bottom:2px solid var(--color-border)}.admin-table th{padding:1rem;text-align:left;font-weight:600;color:var(--color-text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.admin-table td{padding:1rem;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary)}.admin-table tbody tr:hover{background:var(--color-bg-secondary)}.admin-table tbody tr:last-child td{border-bottom:none}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.role-admin{background:#fef3c7;color:#92400e}.role-user{background:#dbeafe;color:#1e40af}.admin-table .status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;width:auto;height:auto;line-height:normal}.admin-table .status-badge:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%}.admin-table .status-active{background:#d1fae5;color:#065f46}.admin-table .status-active:before{background:#10b981}.admin-table .status-inactive{background:#fee2e2;color:#991b1b}.admin-table .status-inactive:before{background:#ef4444}.action-buttons{display:flex;gap:.5rem}.button-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.button-icon:hover{background:var(--color-bg-secondary);border-color:var(--color-primary);color:var(--color-primary)}.button-icon.button-danger:hover{background:#fee2e2;border-color:#dc2626;color:#dc2626}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h2{margin-top:0;margin-bottom:1.5rem;color:var(--color-text-primary)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text-primary);font-size:.875rem}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group select{width:100%;padding:.625rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background:var(--color-bg-secondary);cursor:not-allowed}.form-group input[type=checkbox]{width:auto;margin-right:.5rem}.form-group small{display:block;margin-top:.25rem;font-size:.75rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.button{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:1px solid transparent;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.button-primary{background:var(--color-primary);color:#fff}.button-primary:hover{background:var(--color-primary-dark)}.button-ghost{background:transparent;border-color:var(--color-border);color:var(--color-text-secondary)}.button-ghost:hover{background:var(--color-bg-secondary);border-color:var(--color-primary);color:var(--color-primary)}.button-sm{padding:.375rem .75rem;font-size:.8125rem}.button-lg{padding:.75rem 1.5rem;font-size:1rem}.button-icon.button-lg{width:40px;height:40px}.form-group input[type=number],.form-group textarea{width:100%;padding:.625rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;transition:border-color .2s;font-family:inherit}.form-group textarea{resize:vertical;min-height:80px}.form-group input[type=number]:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-select{width:100%;padding:.625rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;background:#fff;cursor:pointer;transition:border-color .2s}.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:1rem;color:#1e40af;font-size:.875rem}.info-box ul{margin-bottom:0}.alert{padding:1rem;border-radius:8px;font-size:.875rem}.alert-success{background:#d1fae5;border:1px solid #6ee7b7;color:#065f46}.badge{display:inline-block;padding:.25rem .625rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);text-transform:capitalize}.row-selected{background:#ecfdf5!important;border-left:3px solid #059669}.row-selected:hover{background:#d1fae5!important}.checkbox-container{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative}.checkbox-container input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkbox-custom{position:relative;height:24px;width:24px;border:2px solid #d1d5db;border-radius:6px;background-color:#fff;transition:all .2s ease}.checkbox-container:hover .checkbox-custom{border-color:var(--color-primary)}.checkbox-container input[type=checkbox]:checked~.checkbox-custom{background-color:#059669;border-color:#059669}.checkbox-custom:after{content:"";position:absolute;display:none;left:7px;top:3px;width:6px;height:11px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-container input[type=checkbox]:checked~.checkbox-custom:after{display:block}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.page-header-actions{display:flex;gap:var(--spacing-sm)}.connections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.connection-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);transition:all .2s ease;position:relative;display:flex;flex-direction:column;gap:var(--spacing-md)}.connection-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.connection-card.inactive{opacity:.6;background:var(--color-bg-secondary)}.connection-card-header{display:flex;align-items:center;gap:var(--spacing-sm)}.connection-icon{font-size:1.5rem;color:var(--color-primary)}.connection-type{font-size:.75rem;font-weight:var(--font-weight-semibold);text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.5px}.connection-card-body{flex:1}.connection-name{font-size:1.125rem;font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-xs)}.connection-description{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.connection-info{font-size:.8125rem;color:var(--color-text-light);font-family:var(--font-family-mono);word-break:break-all}.connection-card-footer{display:flex;gap:var(--spacing-xs);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.connection-inactive-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:var(--color-text-secondary);color:#fff;padding:2px 8px;border-radius:12px;font-size:.6875rem;font-weight:var(--font-weight-semibold)}.empty-state{grid-column:1 / -1;text-align:center;padding:var(--spacing-2xl);background:var(--color-bg-secondary);border-radius:var(--radius-md);border:2px dashed var(--color-border)}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:1.125rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--spacing-lg)}.modal-container{background:var(--color-bg);border-radius:var(--radius-md);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);z-index:var(--z-modal)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1.25rem;font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-text-light);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:var(--transition-fast)}.modal-close:hover{background:var(--color-bg-secondary);color:var(--color-text)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-lg);margin-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);font-size:.875rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-family);color:var(--color-text);background-color:var(--color-bg);transition:var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #cc33341a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-light)}.form-group small{display:block;margin-top:var(--spacing-xs);font-size:.75rem;color:var(--color-text-light)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.alert-error{background:#fee2e2;color:var(--color-error);border:1px solid #fecaca}@media (max-width: 768px){.page-header{flex-direction:column}.connections-grid{grid-template-columns:1fr}.modal-container{max-width:100%;max-height:100vh;border-radius:0}}.preview-modal{max-width:90vw;width:1200px;max-height:90vh}.preview-modal .modal-body{max-height:calc(90vh - 200px);overflow:auto}.preview-connection-name{color:var(--color-text-secondary);font-size:.875rem;margin-top:.25rem}.preview-empty{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.preview-stats{display:flex;gap:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}.preview-stats p{display:flex;align-items:center;gap:var(--spacing-xs);margin:0;font-size:.875rem}.preview-stats svg{color:var(--color-primary);font-size:1.125rem}.preview-limit-controls{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background:var(--color-bg-secondary);border-radius:var(--radius-sm)}.preview-limit-controls label{font-size:.875rem;font-weight:var(--font-weight-medium);color:var(--color-text)}.preview-limit-controls select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;background:var(--color-bg);color:var(--color-text)}.preview-table-scroll{overflow:auto;max-height:500px}.preview-table{width:100%;border-collapse:collapse;font-size:.875rem}.preview-table thead{position:sticky;top:0;background:var(--color-bg-secondary);z-index:10}.preview-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text);border-bottom:2px solid var(--color-border);white-space:nowrap}.preview-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);color:var(--color-text-secondary)}.preview-table tbody tr:hover{background:var(--color-bg-secondary)}.preview-row-number{width:40px;text-align:center;color:var(--color-text-light);font-weight:var(--font-weight-medium);background:var(--color-bg-secondary)}.preview-table-container{margin-top:var(--spacing-md)}.classification-type-selector{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem}.classification-type-selector label{font-weight:600;color:var(--text-primary)}.type-select{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;min-width:200px;cursor:pointer}.type-select:disabled{background-color:#f5f5f5;cursor:not-allowed}.unsaved-warning{color:#f59e0b;font-size:.9rem;font-weight:500}.classification-description{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:#eff6ff;border-left:4px solid #3b82f6;border-radius:4px;margin-bottom:1.5rem;color:#1e40af;font-size:.95rem}.classification-description svg{font-size:1.2rem;flex-shrink:0}.classification-stats{display:flex;gap:2rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.9rem;color:var(--text-secondary)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.classification-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;margin-bottom:1.5rem}.classification-table{width:100%;border-collapse:collapse}.classification-table thead{background:var(--primary-color);color:#fff}.classification-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.classification-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .15s}.classification-table tbody tr:hover{background-color:#f9fafb}.classification-table tbody tr:last-child{border-bottom:none}.classification-table td{padding:1rem;vertical-align:middle}.package-code-cell{font-family:Courier New,monospace;font-size:.95rem}.classification-value-cell{padding:.75rem 1rem}.classification-select,.classification-input{width:100%;padding:.5rem .75rem;border:2px solid var(--border-color);border-radius:6px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.classification-select:focus,.classification-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #cc33341a}.classification-input[type=number]{text-align:center;font-weight:500}.status-cell{text-align:center}.status-badge{display:inline-block;width:28px;height:28px;border-radius:50%;font-weight:700;font-size:1.1rem;line-height:28px;text-align:center}.status-complete{background-color:#10b981;color:#fff}.status-pending{background-color:#e5e7eb;color:#9ca3af}.classification-footer{display:flex;justify-content:center;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.button-large{padding:.875rem 2rem;font-size:1.05rem;min-width:250px}@media (max-width: 768px){.classification-type-selector{flex-direction:column;align-items:flex-start}.classification-stats{flex-direction:column;gap:1rem}.classification-table-container{overflow-x:auto}.classification-table{min-width:600px}}.flujo-dashboard{padding:20px;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;gap:20px}.dashboard-header h1{color:#2ecc71;margin-bottom:5px}.btn-sync{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-sync:hover:not(:disabled){background:#2980b9;transform:translateY(-1px);box-shadow:0 4px 8px #3498db4d}.btn-sync svg{font-size:18px}.dashboard-subtitle{color:#7f8c8d;font-size:14px}.dashboard-actions{display:flex;gap:10px}.filtro-fecha-section{background:#fff;padding:10px 20px;border-radius:8px;box-shadow:0 1px 4px #00000014;margin-bottom:20px}.filtro-fecha-content{display:flex;align-items:center;gap:12px}.filtro-icon{font-size:18px;color:#3498db}.filtro-fecha-content label{font-weight:500;color:#2c3e50;font-size:13px;white-space:nowrap}.input-fecha{padding:6px 10px;border:1px solid #dfe6e9;border-radius:4px;font-size:13px;color:#2c3e50}.btn-aplicar{background:#2ecc71;color:#fff;border:none;padding:6px 16px;border-radius:4px;font-weight:600;font-size:13px;cursor:pointer;transition:background .2s}.btn-aplicar:hover{background:#27ae60}.fecha-actual{color:#95a5a6;font-size:12px;margin-left:auto}.section-title{display:flex;align-items:baseline;gap:10px;margin-bottom:15px;margin-top:25px}.section-title h2{color:#34495e;font-size:20px;margin:0}.section-subtitle{color:#7f8c8d;font-size:13px}.resumen-section{margin-bottom:40px}.resumen-section h2{color:#34495e;margin-bottom:20px;font-size:22px}.resumen-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.resumen-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.resumen-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.resumen-card.total{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.resumen-card.warning{border:2px solid #f39c12}.resumen-card.semaforo{border:3px solid #95a5a6}.resumen-card.semaforo.verde{border-color:#27ae60;background:linear-gradient(135deg,#f0fff4,#e8f8f0)}.resumen-card.semaforo.amarillo{border-color:#f39c12;background:linear-gradient(135deg,#fffbf0,#fff4e0)}.resumen-card.semaforo.rojo{border-color:#e74c3c;background:linear-gradient(135deg,#fff5f5,#ffe8e8)}.card-value-small{font-size:16px;font-weight:600;margin-bottom:8px;color:#2c3e50;line-height:1.4}.card-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;opacity:.8;margin-bottom:8px}.card-value{font-size:28px;font-weight:700;margin-bottom:5px}.card-value.usd{color:#27ae60}.card-value.ars{color:#3498db}.card-value.ingreso{color:#27ae60}.card-value.egreso{color:#e74c3c}.card-value.egreso-proyectado{color:#e67e22}.resumen-card.total-egreso{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.resumen-card.total-egreso .card-label{opacity:.9}.resumen-card.total-egreso-proyectado{background:linear-gradient(135deg,#e67e22,#d35400);color:#fff}.resumen-card.total-egreso-proyectado .card-label{opacity:.9}.liquidez-row{display:flex;gap:20px;margin-bottom:30px}.semaforo-card{flex:1;background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:3px solid #95a5a6}.semaforo-card.verde{border-color:#27ae60;background:linear-gradient(135deg,#f0fff4,#e8f8f0)}.semaforo-card.amarillo{border-color:#f39c12;background:linear-gradient(135deg,#fffbf0,#fff4e0)}.semaforo-card.rojo{border-color:#e74c3c;background:linear-gradient(135deg,#fff5f5,#ffe8e8)}.config-alertas-card{flex:1;background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.config-items{display:flex;flex-direction:column;gap:12px;margin-top:12px}.config-item-inline{display:flex;align-items:center;gap:10px}.config-label{font-size:13px;color:#7f8c8d;min-width:100px}.config-alertas-card .config-value{font-size:14px;font-weight:600;color:#27ae60}.input-config-sm{padding:5px 8px;border:1px solid #dfe6e9;border-radius:4px;font-size:13px;width:120px}.btn-edit-sm,.btn-save-sm,.btn-cancel-sm{padding:4px 10px;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.btn-edit-sm{background:#3498db;color:#fff}.btn-edit-sm:hover{background:#2980b9}.btn-save-sm{background:#27ae60;color:#fff}.btn-save-sm:hover{background:#229954}.btn-cancel-sm{background:#95a5a6;color:#fff}.btn-cancel-sm:hover{background:#7f8c8d}@media (max-width: 768px){.liquidez-row{flex-direction:column}}.card-subtext{font-size:12px;opacity:.7}.medios-pago-list{margin-top:30px}.medios-pago-list h3{color:#34495e;margin-bottom:15px;font-size:18px}.medios-pago-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 4px #00000014;overflow:hidden}.medios-pago-table{width:100%;border-collapse:collapse;font-size:13px}.medios-pago-table thead{background:#f8f9fa}.medios-pago-table th{padding:10px 15px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e9ecef;font-size:12px;text-transform:uppercase;letter-spacing:.3px}.medios-pago-table th.text-right{text-align:right}.medios-pago-table tbody tr{border-bottom:1px solid #f1f3f4;transition:background .15s}.medios-pago-table tbody tr:hover{background:#f8f9fa}.medios-pago-table tbody tr:last-child{border-bottom:none}.medios-pago-table td{padding:10px 15px;color:#2c3e50}.medios-pago-table .tipo-cell{text-transform:capitalize;color:#7f8c8d}.medios-pago-table .moneda-cell{font-weight:600;color:#95a5a6}.medios-pago-table .saldo-cell{text-align:right;font-weight:600;font-family:Courier New,monospace}.medios-pago-table .saldo-cell.usd{color:#27ae60}.medios-pago-table .saldo-cell.ars{color:#3498db}.medios-pago-table .saldo-cell.negativo{color:#e74c3c}.proyeccion-section{margin-top:40px}.proyeccion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.proyeccion-header h2{color:#34495e;font-size:22px;margin:0}.filtros-fecha{display:flex;gap:15px;align-items:center}.filtro-item{display:flex;align-items:center;gap:8px}.filtro-item label{font-size:14px;color:#7f8c8d;font-weight:500}.filtro-item input[type=date]{padding:8px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;color:#2c3e50}.btn-actualizar{background:#2ecc71;color:#fff;border:none;padding:8px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.btn-actualizar:hover{background:#27ae60}.proyeccion-resumen{margin-bottom:30px}.proyeccion-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.proyeccion-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.proyeccion-card h4{margin:0 0 15px;font-size:16px;text-transform:uppercase;letter-spacing:.5px}.proyeccion-card.ingresos{border-left:5px solid #27ae60}.proyeccion-card.ingresos h4{color:#27ae60}.proyeccion-card.egresos{border-left:5px solid #e74c3c}.proyeccion-card.egresos h4{color:#e74c3c}.proyeccion-card.saldo-final{border-left:5px solid #3498db;background:linear-gradient(135deg,#f8f9fa,#e8f4f8)}.proyeccion-card.saldo-final h4{color:#3498db}.moneda-row{display:flex;justify-content:space-between;padding:8px 0;font-size:15px;color:#2c3e50}.moneda-row span:last-child{font-weight:600}.breakdown{margin-top:10px;padding-top:10px;border-top:1px solid #ecf0f1}.breakdown small{color:#7f8c8d;font-size:12px}.total-final{margin-top:15px;padding-top:15px;border-top:2px solid #3498db;text-align:center}.total-final strong{font-size:20px;color:#3498db}.tabla-semanal{margin-top:30px}.tabla-semanal h3{color:#34495e;margin-bottom:15px;font-size:18px}.table-container{overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.tabla-semanal table{width:100%;border-collapse:collapse;min-width:1000px}.tabla-semanal thead{background:#34495e;color:#fff}.tabla-semanal th{padding:15px 12px;text-align:left;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tabla-semanal tbody tr{border-bottom:1px solid #ecf0f1;transition:background .2s}.tabla-semanal tbody tr:hover{background:#f8f9fa}.tabla-semanal td{padding:12px;font-size:14px;color:#2c3e50}.tabla-semanal td.periodo{font-size:12px;color:#7f8c8d}.tabla-semanal td.ingreso{color:#27ae60;font-weight:500}.tabla-semanal td.egreso{color:#e74c3c;font-weight:500}.tabla-semanal td.saldo-total{background:#f8f9fa;font-size:15px}.tabla-semanal td.saldo-total strong{color:#2ecc71}.configuraciones-section{margin:30px 0;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.configuraciones-section h3{color:#34495e;margin-bottom:20px;font-size:18px}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.config-item{display:flex;flex-direction:column;gap:10px}.config-item label{font-size:14px;font-weight:600;color:#2c3e50}.config-display{display:flex;align-items:center;gap:15px}.config-value{font-size:18px;font-weight:700;color:#27ae60}.config-edit{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.input-config{padding:8px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;color:#2c3e50;flex:1;min-width:150px}.btn-edit,.btn-save,.btn-cancel{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-edit{background:#3498db;color:#fff}.btn-edit:hover{background:#2980b9}.btn-save{background:#27ae60;color:#fff}.btn-save:hover{background:#229954}.btn-cancel{background:#95a5a6;color:#fff}.btn-cancel:hover{background:#7f8c8d}@media (max-width: 768px){.proyeccion-header{flex-direction:column;align-items:flex-start}.filtros-fecha{width:100%;flex-wrap:wrap}.resumen-cards,.proyeccion-cards,.cuentas-grid,.config-grid{grid-template-columns:1fr}}.flujo-proyectado{padding:20px;max-width:100%;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.page-header h1{color:#2ecc71;margin:0;display:flex;align-items:center;gap:10px;font-size:28px}.page-header h1 svg{font-size:32px}.page-subtitle{color:#7f8c8d;font-size:14px;margin:4px 0 0}.header-actions{display:flex;gap:12px;align-items:center}.vista-selector{display:flex;background:#ecf0f1;border-radius:8px;padding:4px;gap:4px}.vista-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:#7f8c8d;font-size:13px;cursor:pointer;transition:all .2s ease}.vista-btn:hover{background:#ffffff80;color:#2c3e50}.vista-btn.active{background:#fff;color:#2ecc71;box-shadow:0 2px 4px #0000001a;font-weight:500}.vista-btn svg{font-size:18px}.cantidad-select{padding:8px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s ease}.cantidad-select:focus{outline:none;border-color:#2ecc71;box-shadow:0 0 0 3px #2ecc711a}.semanas-select{padding:8px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s ease}.semanas-select:focus{outline:none;border-color:#2ecc71;box-shadow:0 0 0 3px #2ecc711a}.btn-icon{background:#ecf0f1;border:2px solid #bdc3c7;padding:10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;color:#2c3e50;transition:all .2s ease;min-width:44px;min-height:44px}.btn-icon:hover{background:#bdc3c7;border-color:#95a5a6;transform:translateY(-1px)}.moneda-select{padding:8px 12px;border:2px solid #2ecc71;border-radius:6px;font-size:14px;font-weight:600;background:#e8f8f5;color:#27ae60;cursor:pointer;transition:all .2s ease}.moneda-select:focus{outline:none;box-shadow:0 0 0 3px #2ecc7133}.btn-sync-icon{background:#3498db;color:#fff}.btn-sync-icon:hover:not(:disabled){background:#2980b9}.btn-sync-icon:disabled{opacity:.6;cursor:not-allowed}.btn-sync-icon .spinning{animation:spin 1s linear infinite}.btn-primary{background:#2ecc71;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .2s ease}.btn-primary:hover{background:#27ae60;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:#95a5a6;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .2s ease}.btn-secondary:hover{background:#7f8c8d}.cambios-pendientes-banner{background:#fff3cd;border:1px solid #ffc107;padding:12px 20px;border-radius:6px;margin-bottom:20px;text-align:center;font-weight:500;color:#856404}.matriz-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 240px)}.matriz-table{width:100%;border-collapse:collapse;font-size:13px}.matriz-table thead{position:sticky;top:0;z-index:10;background:#2c3e50}.matriz-table th{padding:12px 16px;text-align:left;font-weight:600;color:#fff!important;border-right:1px solid #34495e;background:#2c3e50}.matriz-table th:last-child{border-right:none}.header-item{min-width:250px;position:sticky;left:0;z-index:11;background:#2c3e50!important;color:#fff!important}.header-periodo{min-width:140px;text-align:center!important;color:#fff!important}.header-saldo{min-width:120px;text-align:right!important;color:#fff!important;background:#27ae60!important}.periodo-header{display:flex;flex-direction:column;gap:4px;color:#fff!important}.periodo-semana{font-size:13px;font-weight:600;color:#fff!important}.periodo-fechas{font-size:11px;opacity:.9;font-weight:400;color:#fff!important}.matriz-table tbody tr{transition:background .2s ease}.matriz-table td{padding:10px 16px;border-bottom:1px solid #ecf0f1;border-right:1px solid #ecf0f1}.matriz-table td:last-child{border-right:none}.seccion-header{background:#34495e!important}.seccion-header td{color:#fff;font-size:14px;font-weight:600;padding:14px 16px!important;letter-spacing:.5px}.item-nombre{font-weight:500;color:#2c3e50;position:sticky;left:0;background:#fff;z-index:2;display:flex;align-items:center;gap:8px}.fila-item:hover .item-nombre{background:#f8f9fa}.item-indent{color:#95a5a6;font-weight:400}.item-tipo,.item-fuente{font-size:11px;padding:2px 8px;border-radius:4px;background:#ecf0f1;color:#7f8c8d;font-weight:400;text-transform:capitalize}.item-fuente{background:#e8f5e9;color:#2e7d32}.celda-valor{text-align:right;padding:4px 8px!important}.cell-value{padding:8px 12px;border-radius:4px;cursor:default;position:relative;display:flex;align-items:center;justify-content:flex-end;gap:6px;transition:all .2s ease}.cell-value.editable{cursor:pointer;border:1px dashed #bdc3c7}.cell-value.editable:hover{background:#ecf0f1;border-color:#95a5a6}.cell-value.negativo{color:#c0392b}.edit-icon{opacity:0;font-size:14px;color:#95a5a6;transition:opacity .2s ease}.cell-value.editable:hover .edit-icon{opacity:1}.cell-input{width:100%;padding:6px 10px;border:2px solid #2ecc71;border-radius:4px;font-size:13px;text-align:right;font-family:inherit}.cell-input:focus{outline:none;box-shadow:0 0 0 3px #2ecc7133}.fila-total{background:#ecf0f1!important;font-weight:600}.fila-total.ingreso{background:#d5f4e6!important;color:#27ae60}.fila-total.egreso{background:#fadbd8!important;color:#c0392b}.fila-total td{border-bottom:2px solid #bdc3c7!important}.celda-total{text-align:right;font-weight:600;font-size:14px}.celda-saldo{text-align:right;font-weight:600;background:#2ecc7114;min-width:100px}.celda-saldo.positivo{color:#27ae60}.celda-saldo.negativo{color:#e74c3c}.celda-saldo.celda-total{background:#2ecc7126;font-size:14px}.fila-resultado{background:#2c3e50!important;color:#fff;font-weight:700}.fila-resultado td{padding:14px 16px!important;font-size:15px;border-bottom:none!important}.celda-resultado{text-align:right;font-weight:700}.celda-resultado.positivo{color:#2ecc71}.celda-resultado.negativo{color:#e74c3c}.loading{text-align:center;padding:60px 20px;color:#7f8c8d;font-size:16px}@media (max-width: 1024px){.matriz-container{max-height:calc(100vh - 280px)}.header-item{min-width:200px}.header-periodo{min-width:120px}.page-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}}@media (max-width: 768px){.flujo-proyectado{padding:12px}.page-header h1{font-size:22px}.matriz-table{font-size:12px}.header-item{min-width:160px}.header-periodo{min-width:100px}.btn-primary,.btn-secondary{font-size:12px;padding:8px 14px}}.fila-saldos-cobrar{background:#e3f2fd!important}.fila-saldos-cobrar:hover{background:#bbdefb!important}.fila-saldos-cobrar .item-nombre{background:#e3f2fd}.fila-saldos-cobrar:hover .item-nombre{background:#bbdefb}.fila-saldos-cobrar .item-fuente{background:#90caf9;color:#1565c0}.cell-value.saldo-cobrar{color:#1976d2;font-weight:500;position:relative}.cell-value.saldo-cobrar.con-detalle{cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}.cell-value.saldo-cobrar.con-detalle:hover{color:#0d47a1}.tooltip-detalle{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;border-radius:8px;padding:12px;min-width:280px;max-width:320px;box-shadow:0 10px 25px #0000004d;z-index:1000;margin-bottom:8px}.tooltip-detalle:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:#1e293b}.cell-value.saldo-cobrar.con-detalle:hover .tooltip-detalle{display:block}.tooltip-header{font-size:12px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #334155}.tooltip-lista{display:flex;flex-direction:column;gap:6px}.tooltip-item{display:flex;justify-content:space-between;align-items:center;font-size:13px;gap:12px}.tooltip-nombre{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#e2e8f0}.tooltip-monto{font-weight:600;color:#4ade80;white-space:nowrap}.tooltip-total{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid #334155;font-weight:700;font-size:14px}.tooltip-total span:last-child{color:#60a5fa}.medios-pago-page{padding:20px;max-width:1400px;margin:0 auto}.table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #ecf0f1}.table td{padding:16px;border-bottom:1px solid #ecf0f1;color:#2c3e50}.tipo-cell{display:flex;align-items:center;gap:8px;font-weight:500}.tipo-icon{font-size:20px}.saldo-actual{background:#e8f5e9;color:#2e7d32}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:700px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.disponibilidad-grid,.filters-row{grid-template-columns:1fr}.table-responsive{overflow-x:scroll}}.proveedor-autocomplete{position:relative;width:100%}.proveedor-nombre{flex:1;font-size:.875rem;color:var(--text-primary, #1f2937)}.proveedor-cuit{font-size:.75rem;color:var(--text-muted, #6b7280)}.subconcepto-autocomplete{position:relative;width:100%}.autocomplete-input-wrapper{position:relative;display:flex;align-items:center}.autocomplete-input{width:100%;padding:.625rem 2.5rem .625rem .75rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.875rem;background-color:var(--bg-input, #fff);color:var(--text-primary, #1f2937);transition:border-color .15s ease,box-shadow .15s ease}.autocomplete-input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.autocomplete-input:disabled{background-color:var(--bg-disabled, #f3f4f6);cursor:not-allowed}.autocomplete-input.has-selection{border-color:var(--success-color, #10b981);background-color:#10b9810d}.selection-indicator{position:absolute;right:.75rem;color:var(--success-color, #10b981);display:flex;align-items:center}.loading-indicator{position:absolute;right:.75rem;color:var(--text-muted, #6b7280);font-size:.75rem}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background-color:var(--bg-card, #fff);border:1px solid var(--border-color, #d1d5db);border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;max-height:240px;overflow-y:auto;z-index:1000}.dropdown-item{padding:.625rem .75rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background-color .1s ease}.dropdown-item:hover,.dropdown-item.highlighted{background-color:var(--bg-hover, #f3f4f6)}.dropdown-item:not(:last-child){border-bottom:1px solid var(--border-light, #e5e7eb)}.subconcepto-nombre{flex:1;font-size:.875rem;color:var(--text-primary, #1f2937)}.subconcepto-padre{font-size:.75rem;color:var(--text-muted, #6b7280);background-color:#f1f5f9;padding:2px 6px;border-radius:4px}.dropdown-item.crear-nuevo{background-color:var(--bg-subtle, #f9fafb);color:var(--primary-color, #3b82f6);font-size:.875rem}.dropdown-item.crear-nuevo:hover,.dropdown-item.crear-nuevo.highlighted{background-color:#3b82f61a}.crear-icon{font-size:1rem}.dropdown-item.crear-nuevo strong{color:var(--text-primary, #1f2937)}.movimientos-fondos-page{padding:20px;max-width:1600px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{display:flex;align-items:center;gap:12px}.page-title h1{color:#2ecc71;margin:0;font-size:28px}.page-icon{font-size:32px;color:#2ecc71}.filters-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;margin-bottom:24px}.filters-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:13px;font-weight:600;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.filter-group select{padding:10px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;color:#2c3e50;background:#fff;cursor:pointer;transition:border-color .2s ease}.filter-group select:hover{border-color:#2ecc71}.filter-group select:focus{outline:none;border-color:#2ecc71;box-shadow:0 0 0 3px #2ecc711a}.disponibilidad-summary{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;margin-bottom:24px}.disponibilidad-summary h3{margin:0 0 16px;color:#2c3e50;font-size:18px}.disponibilidad-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.disponibilidad-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;padding:16px;color:#fff}.disponibilidad-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:14px;opacity:.95}.disponibilidad-nombre{font-weight:500}.disponibilidad-monto{display:flex;align-items:baseline;gap:8px;font-size:24px;font-weight:700}.disponibilidad-monto .moneda{font-size:14px;font-weight:600;opacity:.8}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.card-header{padding:20px 24px;border-bottom:1px solid #ecf0f1;background:#f8f9fa}.card-header h2{margin:0;color:#2c3e50;font-size:18px}.card-body{padding:24px}.table{width:100%;border-collapse:collapse}.table thead{background:#f8f9fa}.table th{padding:8px 10px;text-align:left;font-size:11px;font-weight:600;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #ecf0f1}.table td{padding:8px 10px;border-bottom:1px solid #ecf0f1;color:#2c3e50;font-size:13px}.table tbody tr{transition:background-color .2s ease}.table tbody tr:hover{background-color:#f8f9fa}.table tbody tr.inactive{opacity:.6}.tipo-cell{display:flex;align-items:center;gap:6px;font-weight:500;font-size:12px}.tipo-icon{font-size:16px}.tipo-icon.efectivo{color:#2ecc71}.tipo-icon.banco{color:#3498db}.tipo-icon.cheque{color:#9b59b6}.tipo-icon.ingreso{color:#27ae60}.tipo-icon.egreso{color:#e74c3c}.monto-ingreso{color:#27ae60;font-weight:600}.monto-egreso{color:#e74c3c;font-weight:600}.badge-cierto{background:#d4edda;color:#155724}.badge-proyectado{background:#fff3cd;color:#856404}.badge-cancelado{background:#f8d7da;color:#721c24}.table tbody tr.cancelled{opacity:.5;text-decoration:line-through}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:20px;border-top:1px solid #ecf0f1}.pagination span{color:#7f8c8d;font-size:14px}.card-header{display:flex;justify-content:space-between;align-items:center}.total-count{color:#7f8c8d;font-size:14px;font-weight:500}.button-success:hover{background:#d4edda;color:#155724}.filter-group input[type=date]{padding:10px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;color:#2c3e50;background:#fff;cursor:pointer;transition:border-color .2s ease}.filter-group input[type=date]:hover{border-color:#2ecc71}.filter-group input[type=date]:focus{outline:none;border-color:#2ecc71;box-shadow:0 0 0 3px #2ecc711a}.banco-info{display:flex;flex-direction:column;gap:4px}.text-right{text-align:right;font-variant-numeric:tabular-nums}.text-muted{color:#95a5a6;font-size:13px}.badge{display:inline-block;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge-ars{background:#e8f5e9;color:#2e7d32}.badge-usd{background:#e3f2fd;color:#1565c0}.badge-success{background:#d4edda;color:#155724}.badge-secondary{background:#e2e3e5;color:#6c757d}.action-buttons{display:flex;gap:8px}.button{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.button svg{font-size:18px}.button-primary{background:#2ecc71;color:#fff}.button-primary:hover{background:#27ae60;transform:translateY(-1px);box-shadow:0 4px 12px #2ecc714d}.button-ghost{background:transparent;color:#7f8c8d}.button-ghost:hover{background:#ecf0f1;color:#2c3e50}.button-danger:hover{background:#ffebee;color:#c62828}.button-sm{padding:6px 12px;font-size:13px}.button-sm svg{font-size:16px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:700px;width:90%;max-height:92vh;overflow-y:auto;animation:slideUp .3s ease}.modal-content.modal-large{max-width:1100px;width:95%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #ecf0f1}.modal-header h2{margin:0;color:#2c3e50;font-size:20px}.modal-close{background:transparent;border:none;font-size:28px;color:#95a5a6;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#ecf0f1;color:#2c3e50}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #ecf0f1;background:#f8f9fa}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;color:#2c3e50;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2ecc71;box-shadow:0 0 0 3px #2ecc711a}.form-section-title{font-size:14px;font-weight:600;color:#2c3e50;margin:20px 0 12px;padding-bottom:8px;border-bottom:2px solid #ecf0f1}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-size:14px;color:#2c3e50;font-weight:500}.form-help{font-size:11px;color:#7f8c8d;margin-top:4px;font-style:italic}.form-section-title{font-size:14px;font-weight:600;color:#2c3e50;margin:16px 0 12px;padding-bottom:8px;border-bottom:2px solid #3498db}.input-readonly{background-color:#f8f9fa!important;color:#7f8c8d!important;cursor:not-allowed}.loading{text-align:center;padding:40px;color:#95a5a6}.empty-state{text-align:center;padding:60px 20px;color:#95a5a6}@media (max-width: 900px){.form-row-3{grid-template-columns:1fr 1fr}.modal-content.modal-large{max-width:95%;width:95%}}@media (max-width: 768px){.form-row,.form-row-3{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.disponibilidad-grid,.filters-row{grid-template-columns:1fr}.table-responsive{overflow-x:scroll}.modal-content.modal-large{width:100%;max-width:100%;border-radius:0;max-height:100vh}}.tipos-movimiento-page{padding:20px;max-width:1400px;margin:0 auto}.badge-ingreso{background:#d4edda;color:#155724}.badge-egreso{background:#f8d7da;color:#721c24}.badge-transferencia{background:#cce5ff;color:#004085}.badge-cheque{background:#e7e3ff;color:#4c3fb1}.badge-otro{background:#e2e3e5;color:#6c757d}.badge-flujo-ingreso{background:#d1f2eb;color:#0c5460}.badge-flujo-egreso{background:#f5c6cb;color:#721c24}.badge-flujo-neutro{background:#d6d8db;color:#383d41}code{background:#f4f4f4;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:12px;color:#c7254e}.alert{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:14px}.alert-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.table tbody tr.inactive{opacity:.5}.conceptos-gasto-container{padding:20px}.tabs-container{margin-bottom:20px}.tabs-header{display:flex;gap:0;border-bottom:2px solid #e2e8f0;background:#fff;border-radius:8px 8px 0 0;padding:0 16px}.tab-button{display:flex;align-items:center;gap:8px;padding:14px 24px;background:none;border:none;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;position:relative;transition:all .2s}.tab-button:hover{color:#2563eb;background-color:#f8fafc}.tab-button.active{color:#2563eb}.tab-button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background-color:#2563eb}.tab-icon{font-size:18px}.tab-count{background-color:#e2e8f0;color:#475569;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.tab-button.active .tab-count{background-color:#dbeafe;color:#1e40af}.tabs-content{background:#fff;border-radius:0 0 8px 8px;padding:20px;box-shadow:0 1px 3px #0000001a}.subconceptos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.subconceptos-filters{display:flex;gap:12px;align-items:center}.subconceptos-filters input[type=text]{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;min-width:250px}.subconceptos-filters input[type=text]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.concepto-padre-cell{display:flex;align-items:center;gap:6px}.concepto-padre-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:4px;font-size:13px;font-weight:500}.concepto-padre-badge.tipo-ingreso{background-color:#d1fae5;color:#065f46}.concepto-padre-badge.tipo-egreso{background-color:#fee2e2;color:#991b1b}.subconcepto-cell{display:flex;align-items:center;gap:6px}.subconcepto-cell .icon-sub{color:#64748b;font-size:16px}.badge-padre{background-color:#e2e8f0;color:#475569}.text-center{text-align:center;color:#94a3b8;padding:24px!important}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-left{display:flex;align-items:center;gap:12px}.page-icon{font-size:32px;color:#2563eb}.page-header h1{font-size:24px;font-weight:600;color:#1e293b;margin:0}.filtros-card{background:#fff;border-radius:8px;padding:16px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.filtros-row{display:flex;gap:16px;flex-wrap:wrap}.filtro-grupo{display:flex;flex-direction:column;gap:4px}.filtro-grupo label{font-size:13px;font-weight:500;color:#64748b}.filtro-grupo select{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;min-width:150px}.arbol-conceptos{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.tree-node{margin-bottom:4px}.tree-node-content{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:6px;transition:background-color .2s}.tree-node-content:hover{background-color:#f8fafc}.tree-node-left{display:flex;align-items:center;gap:8px;flex:1}.expand-btn{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;font-size:20px;color:#64748b}.expand-btn:hover{color:#2563eb}.expand-placeholder{width:28px}.icon-tipo{font-size:20px}.icon-tipo.tipo-ingreso{color:#10b981}.icon-tipo.tipo-egreso{color:#ef4444}.concepto-info{display:flex;align-items:center;gap:8px}.concepto-nombre{font-size:14px;font-weight:500;color:#1e293b}.concepto-codigo{font-size:13px;color:#64748b}.tree-node-right{display:flex;align-items:center;gap:12px}.concepto-monto{font-size:14px;font-weight:600;color:#0f172a;min-width:100px;text-align:right}.tree-children{border-left:2px solid #e2e8f0;margin-left:14px;padding-left:10px}.tabla-conceptos{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.tabla-conceptos table{width:100%;border-collapse:collapse}.tabla-conceptos thead{background-color:#f8fafc;border-bottom:2px solid #e2e8f0}.tabla-conceptos th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase}.tabla-conceptos td{padding:12px 16px;font-size:14px;color:#1e293b;border-bottom:1px solid #f1f5f9}.tabla-conceptos tr:hover{background-color:#f8fafc}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.badge-ingreso{background-color:#d1fae5;color:#065f46}.badge-egreso{background-color:#fee2e2;color:#991b1b}.badge-recurrente{background-color:#dbeafe;color:#1e40af}.badge-activo{background-color:#d1fae5;color:#065f46}.badge-inactivo{background-color:#f1f5f9;color:#64748b}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover{background-color:#1d4ed8}.btn-secondary{background-color:#f1f5f9;color:#475569}.btn-secondary:hover{background-color:#e2e8f0}.acciones-grupo{display:flex;gap:4px}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:4px;cursor:pointer;font-size:18px;transition:all .2s}.btn-editar{background-color:#dbeafe;color:#1e40af}.btn-editar:hover{background-color:#bfdbfe}.btn-eliminar{background-color:#fee2e2;color:#991b1b}.btn-eliminar:hover{background-color:#fecaca}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content.modal-conceptos{background:#fff;border-radius:12px;width:95%!important;max-width:1100px!important;max-height:92vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:20px;font-weight:600;color:#1e293b;margin:0}.modal-close{background:none;border:none;font-size:32px;color:#64748b;cursor:pointer;line-height:1;padding:0;width:32px;height:32px}.modal-close:hover{color:#1e293b}.modal-form{padding:24px}.form-row{display:flex;gap:16px;margin-bottom:16px}.form-group{flex:1;display:flex;flex-direction:column;gap:6px}.form-group.full-width{flex:1 1 100%}.form-group label{font-size:13px;font-weight:500;color:#64748b;display:flex;align-items:center;gap:6px}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;font-family:inherit}.form-group input[type=text]:focus,.form-group input[type=number]:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input[type=checkbox]{width:16px;height:16px;cursor:pointer}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e2e8f0}.loading{text-align:center;padding:40px;color:#64748b;font-size:14px}.no-data{text-align:center;padding:40px;color:#94a3b8;font-size:14px}@media (max-width: 768px){.form-row,.filtros-row{flex-direction:column}.tree-node-content{flex-direction:column;align-items:flex-start;gap:8px}.tree-node-right{width:100%;justify-content:space-between}.tabla-conceptos{font-size:12px}}.centros-costo-container{padding:1.5rem;max-width:1200px;margin:0 auto}.centros-costo-container .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.centros-costo-container .header-left{display:flex;align-items:center;gap:.75rem}.centros-costo-container .page-icon{font-size:2rem;color:var(--primary-color, #3b82f6)}.centros-costo-container h1{font-size:1.5rem;font-weight:600;color:var(--text-color, #1f2937);margin:0}.centros-costo-container .info-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1rem}.centros-costo-container .info-card p{margin:0;color:#1e40af;font-size:.875rem;line-height:1.5}.centros-costo-container .filtros-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:1rem;margin-bottom:1rem}.centros-costo-container .filtros-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.centros-costo-container .filtro-grupo{display:flex;flex-direction:column;gap:.25rem}.centros-costo-container .filtro-grupo label{font-size:.75rem;font-weight:500;color:var(--text-muted, #6b7280);text-transform:uppercase}.centros-costo-container .filtro-grupo input,.centros-costo-container .filtro-grupo select{padding:.5rem .75rem;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.875rem;min-width:180px}.centros-costo-container .card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.centros-costo-container .tabla-centros{overflow-x:auto}.centros-costo-container .tabla-centros table{width:100%;border-collapse:collapse}.centros-costo-container .tabla-centros th{background:var(--bg-secondary, #f9fafb);padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-muted, #6b7280);border-bottom:1px solid var(--border-color, #e5e7eb)}.centros-costo-container .tabla-centros td{padding:.875rem 1rem;border-bottom:1px solid var(--border-color, #e5e7eb);vertical-align:middle}.centros-costo-container .tabla-centros tr:last-child td{border-bottom:none}.centros-costo-container .tabla-centros tr:hover{background:var(--bg-hover, #f9fafb)}.centros-costo-container .row-inactivo{opacity:.6}.centros-costo-container .col-orden{width:60px;text-align:center}.centros-costo-container .col-estado,.centros-costo-container .col-acciones{width:100px;text-align:center}.centros-costo-container .col-descripcion{color:var(--text-muted, #6b7280);font-size:.875rem}.centros-costo-container .orden-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-secondary, #f3f4f6);border-radius:6px;font-size:.75rem;font-weight:600;color:var(--text-muted, #6b7280)}.centros-costo-container .centro-nombre{display:flex;align-items:center;gap:.5rem}.centros-costo-container .icon-centro{color:var(--primary-color, #3b82f6);font-size:1.25rem}.centros-costo-container .text-muted{color:var(--text-muted, #9ca3af);font-style:italic}.centros-costo-container .badge-toggle{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;border:none;cursor:pointer;transition:all .2s}.centros-costo-container .badge-activo{background:#dcfce7;color:#166534}.centros-costo-container .badge-activo:hover{background:#bbf7d0}.centros-costo-container .badge-inactivo{background:#fee2e2;color:#991b1b}.centros-costo-container .badge-inactivo:hover{background:#fecaca}.centros-costo-container .acciones-grupo{display:flex;gap:.25rem;justify-content:center}.centros-costo-container .btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-size:1rem}.centros-costo-container .btn-editar{background:#eff6ff;color:#2563eb}.centros-costo-container .btn-editar:hover{background:#dbeafe}.centros-costo-container .btn-eliminar{background:#fef2f2;color:#dc2626}.centros-costo-container .btn-eliminar:hover{background:#fee2e2}.centros-costo-container .resumen-card{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem;margin-top:1rem;background:var(--bg-secondary, #f9fafb);border-radius:8px;font-size:.875rem;color:var(--text-muted, #6b7280)}.centros-costo-container .resumen-separador{color:var(--border-color, #e5e7eb)}.centros-costo-container .loading,.centros-costo-container .no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted, #6b7280)}.centros-costo-container .empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.3}.centros-costo-container .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:all .2s}.centros-costo-container .btn-primary{background:var(--primary-color, #3b82f6);color:#fff}.centros-costo-container .btn-primary:hover{background:var(--primary-hover, #2563eb)}.centros-costo-container .btn-secondary{background:var(--bg-secondary, #f3f4f6);color:var(--text-color, #374151)}.centros-costo-container .btn-secondary:hover{background:var(--border-color, #e5e7eb)}.centros-costo-container .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.centros-costo-container .modal-content{background:var(--card-bg, #fff);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.centros-costo-container .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.centros-costo-container .modal-header h2{font-size:1.125rem;font-weight:600;margin:0}.centros-costo-container .modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted, #6b7280);line-height:1;padding:0}.centros-costo-container .modal-close:hover{color:var(--text-color, #1f2937)}.centros-costo-container .modal-form{padding:1.5rem}.centros-costo-container .form-group{margin-bottom:1.25rem}.centros-costo-container .form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-color, #374151);margin-bottom:.5rem}.centros-costo-container .form-group input[type=text],.centros-costo-container .form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.875rem;transition:border-color .2s}.centros-costo-container .form-group input:focus,.centros-costo-container .form-group textarea:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.centros-costo-container .form-group textarea{resize:vertical;min-height:80px}.centros-costo-container .form-help{display:block;margin-top:.375rem;font-size:.75rem;color:var(--text-muted, #6b7280)}.centros-costo-container .checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.centros-costo-container .checkbox-group input[type=checkbox]{width:16px;height:16px;cursor:pointer}.centros-costo-container .modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;margin-top:.5rem;border-top:1px solid var(--border-color, #e5e7eb)}.saldos-cobrar-page{padding:1.5rem;max-width:1600px;margin:0 auto}.saldos-cobrar-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.saldos-cobrar-page .page-title{display:flex;align-items:center;gap:1rem}.saldos-cobrar-page .page-icon{font-size:2.5rem;color:var(--primary-color, #2563eb)}.saldos-cobrar-page .page-title h1{margin:0;font-size:1.75rem;font-weight:600}.saldos-cobrar-page .page-subtitle{margin:.25rem 0 0;color:#64748b;font-size:.9rem}.saldos-cobrar-page .header-actions{display:flex;gap:.75rem}.saldos-cobrar-page .tabs-container{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #e2e8f0;padding-bottom:0}.saldos-cobrar-page .tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.95rem;color:#64748b;transition:all .2s;margin-bottom:-2px}.saldos-cobrar-page .tab:hover{color:#2563eb}.saldos-cobrar-page .tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:500}.saldos-cobrar-page .filtros-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;background:#f8fafc;border-radius:8px}.saldos-cobrar-page .search-box{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.5rem 1rem;min-width:400px;flex:2}.saldos-cobrar-page .search-box svg{color:#94a3b8;font-size:1.1rem}.saldos-cobrar-page .search-box input{border:none;outline:none;font-size:.9rem;width:100%;background:transparent}.saldos-cobrar-page .search-box input::placeholder{color:#94a3b8}.saldos-cobrar-page .filtros-bar select{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;min-width:120px}.saldos-cobrar-page .table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.saldos-cobrar-page .data-table{width:100%;border-collapse:collapse;font-size:.9rem}.saldos-cobrar-page .data-table th{background:#f8fafc;padding:.875rem 1rem;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0;white-space:nowrap}.saldos-cobrar-page .data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.saldos-cobrar-page .data-table th.sortable:hover{background:#e2e8f0}.saldos-cobrar-page .data-table th.sortable svg{font-size:.9rem;vertical-align:middle;margin-left:.25rem;color:#2563eb}.saldos-cobrar-page .data-table td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.saldos-cobrar-page .data-table tbody tr:hover{background:#f8fafc}.saldos-cobrar-page .data-table tbody tr.editing{background:#eff6ff}.saldos-cobrar-page .text-right{text-align:right}.saldos-cobrar-page .nombre-cell{font-weight:500;max-width:200px}.saldos-cobrar-page .total-cell{background:#f1f5f9}.saldos-cobrar-page .editable-cell{background:#fefce8}.saldos-cobrar-page .notas-cell{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#64748b;font-size:.85rem}.saldos-cobrar-page .sin-definir{color:#94a3b8;font-style:italic}.saldos-cobrar-page .monto-cobrar{color:#059669;font-weight:500}.saldos-cobrar-page .positivo{color:#059669}.saldos-cobrar-page .negativo{color:#dc2626}.saldos-cobrar-page .edit-input{width:100%;padding:.5rem;border:1px solid #3b82f6;border-radius:4px;font-size:.9rem}.saldos-cobrar-page .edit-input:focus{outline:none;box-shadow:0 0 0 2px #3b82f633}.saldos-cobrar-page .action-buttons{display:flex;gap:.5rem}.saldos-cobrar-page .btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;background:#f1f5f9;color:#475569;transition:all .2s}.saldos-cobrar-page .btn-icon:hover{background:#e2e8f0;color:#1e293b}.saldos-cobrar-page .btn-icon.btn-save{background:#dcfce7;color:#16a34a}.saldos-cobrar-page .btn-icon.btn-save:hover{background:#bbf7d0}.saldos-cobrar-page .btn-icon.btn-cancel{background:#fee2e2;color:#dc2626}.saldos-cobrar-page .btn-icon.btn-cancel:hover{background:#fecaca}.saldos-cobrar-page .totales-row{background:#f1f5f9;font-weight:600}.saldos-cobrar-page .totales-row td{padding:1rem;border-top:2px solid #e2e8f0}.saldos-cobrar-page .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.saldos-cobrar-page .btn-secondary{background:#f1f5f9;color:#475569}.saldos-cobrar-page .btn-secondary:hover{background:#e2e8f0}.saldos-cobrar-page .btn-secondary:disabled{opacity:.6;cursor:not-allowed}.saldos-cobrar-page .btn-export{background:#059669;color:#fff;margin-left:auto;white-space:nowrap;flex-shrink:0}.saldos-cobrar-page .btn-export:hover{background:#047857}.saldos-cobrar-page .btn-export:disabled{background:#94a3b8;cursor:not-allowed}.saldos-cobrar-page .spinning{animation:spin 1s linear infinite}.saldos-cobrar-page .loading{text-align:center;padding:3rem;color:#64748b}.comparacion-page{padding:20px;max-width:100%;margin:0 auto}.comparacion-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px}.comparacion-page .page-header>div:first-child{flex-shrink:0}.comparacion-page .page-header h1{color:#9b59b6;margin:0;display:flex;align-items:center;gap:10px;font-size:24px}.comparacion-page .page-header h1 svg{font-size:28px}.comparacion-page .page-subtitle{color:#7f8c8d;font-size:13px;margin:4px 0 0}.comparacion-page .header-actions{display:flex;gap:10px;align-items:center}.comparacion-page .filtro-select{padding:8px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.comparacion-page .filtro-select:focus{outline:none;border-color:#9b59b6;box-shadow:0 0 0 3px #9b59b61a}.comparacion-page .moneda-select{padding:8px 12px;border:2px solid #3498db;border-radius:6px;font-size:14px;font-weight:600;background:#ebf5fb;color:#2980b9;cursor:pointer}.comparacion-page .moneda-select:focus{outline:none;border-color:#2980b9;box-shadow:0 0 0 3px #3498db33}.comparacion-page .vista-selector{display:flex;background:#ecf0f1;border-radius:8px;padding:4px;gap:4px}.comparacion-page .vista-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:#7f8c8d;font-size:13px;cursor:pointer;transition:all .2s ease}.comparacion-page .vista-btn:hover{background:#ffffff80;color:#2c3e50}.comparacion-page .vista-btn.active{background:#fff;color:#9b59b6;box-shadow:0 2px 4px #0000001a;font-weight:500}.comparacion-page .vista-btn svg{font-size:18px}.comparacion-page .cantidad-select{padding:8px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.comparacion-page .cantidad-select:focus{outline:none;border-color:#9b59b6;box-shadow:0 0 0 3px #9b59b61a}.comparacion-page .btn-icon{padding:10px;border:none;border-radius:8px;background:#ecf0f1;color:#7f8c8d;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.comparacion-page .btn-icon:hover{background:#9b59b6;color:#fff}.comparacion-page .btn-icon svg{font-size:20px}.resumen-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}.resumen-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #00000014;border-left:4px solid transparent}.resumen-card.proyectado{border-left-color:#3498db}.resumen-card.proyectado .card-icon{background:#3498db1a;color:#3498db}.resumen-card.real{border-left-color:#e67e22}.resumen-card.real .card-icon{background:#e67e221a;color:#e67e22}.resumen-card.diferencia.positivo{border-left-color:#27ae60}.resumen-card.diferencia.positivo .card-icon{background:#27ae601a;color:#27ae60}.resumen-card.diferencia.negativo{border-left-color:#e74c3c}.resumen-card.diferencia.negativo .card-icon{background:#e74c3c1a;color:#e74c3c}.card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.card-icon svg{font-size:24px}.card-content{display:flex;flex-direction:column;gap:4px}.card-label{font-size:13px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.card-value{font-size:24px;font-weight:600;color:#2c3e50}.card-variacion{font-size:14px;font-weight:500}.resumen-card.diferencia.positivo .card-variacion{color:#27ae60}.resumen-card.diferencia.negativo .card-variacion{color:#e74c3c}.empty-state{background:#fff;border-radius:12px;padding:60px 40px;text-align:center;color:#7f8c8d}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.3}.empty-state p{margin:0;font-size:16px}.empty-hint{font-size:14px!important;margin-top:8px!important;opacity:.7}.comparacion-container{background:#fff;border-radius:12px;overflow-x:auto;box-shadow:0 2px 8px #00000014}.comparacion-table{width:100%;border-collapse:collapse;font-size:13px}.comparacion-table th{background:#f8f9fa;padding:12px 8px;text-align:center;font-weight:600;color:#2c3e50;border-bottom:2px solid #ecf0f1;position:sticky;top:0;z-index:10}.comparacion-table .header-concepto,.comparacion-table .header-tipo{text-align:left;min-width:150px}.comparacion-table .header-periodo{min-width:180px;border-left:1px solid #ecf0f1}.comparacion-table .header-total{min-width:180px;background:#e8f5e9;border-left:2px solid #27ae60}.periodo-header{display:flex;flex-direction:column;gap:2px}.periodo-etiqueta{font-size:12px;font-weight:600;color:#2c3e50}.subheader th{background:#f1f3f4;padding:6px 4px;font-size:11px;font-weight:500;color:#7f8c8d;border-bottom:1px solid #ecf0f1}.sub-proy{color:#3498db!important}.sub-real{color:#e67e22!important}.sub-var{color:#9b59b6!important}.seccion-header{background:#f8f9fa}.seccion-header td{padding:10px 12px;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-top:2px solid #ecf0f1}.seccion-header.egreso td{color:#e74c3c;background:#fef5f5}.seccion-header.ingreso td{color:#27ae60;background:#f0fff4}.fila-concepto{transition:background-color .15s ease}.fila-concepto:hover{background:#f8f9fa}.fila-concepto td{padding:10px 8px;border-bottom:1px solid #f1f3f4}.celda-nombre{text-align:left;font-weight:500;color:#2c3e50;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.celda-tipo{text-align:center;font-size:11px;font-weight:500;border-radius:4px;padding:4px 8px!important}.celda-tipo.egreso{color:#e74c3c;background:#fef5f5}.celda-tipo.ingreso{color:#27ae60;background:#f0fff4}.celda-proy,.celda-real,.celda-var{text-align:right;font-variant-numeric:tabular-nums}.celda-proy{color:#3498db;border-left:1px solid #f1f3f4}.celda-real{color:#e67e22}.celda-var{font-weight:500}.celda-var.positivo{color:#27ae60;background:#27ae600d}.celda-var.negativo{color:#e74c3c;background:#e74c3c0d}.celda-var.neutro{color:#7f8c8d}.celda-total-proy,.celda-total-real,.celda-total-var{text-align:right;font-weight:600;background:#f8f9fa;border-left:2px solid #27ae60;font-variant-numeric:tabular-nums}.celda-total-proy{color:#3498db}.celda-total-real{color:#e67e22}.celda-total-var.positivo{color:#27ae60;background:#27ae601a}.celda-total-var.negativo{color:#e74c3c;background:#e74c3c1a}.comparacion-page .loading{background:#fff;border-radius:12px;padding:60px;text-align:center;color:#7f8c8d;font-size:16px}@media (max-width: 1400px){.comparacion-page .page-header{flex-direction:column;align-items:flex-start}.comparacion-page .header-actions{width:100%;flex-wrap:wrap}}@media (max-width: 1200px){.resumen-cards{grid-template-columns:1fr}}@media (max-width: 768px){.comparacion-page .page-header h1{font-size:20px}.comparacion-page .page-header h1 svg{font-size:24px}.comparacion-container{margin:0 -20px;border-radius:0}}.flujo-real-page{padding:20px;max-width:100%;margin:0 auto}.flujo-real-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px}.flujo-real-page .page-header h1{color:#2980b9;margin:0;display:flex;align-items:center;gap:10px;font-size:24px}.flujo-real-page .page-header h1 svg{font-size:28px}.flujo-real-page .page-subtitle{color:#7f8c8d;font-size:13px;margin:4px 0 0}.flujo-real-page .header-actions{display:flex;gap:10px;align-items:center}.flujo-real-page .moneda-select{padding:8px 12px;border:2px solid #2980b9;border-radius:6px;font-size:14px;font-weight:600;background:#ebf5fb;color:#2980b9;cursor:pointer}.flujo-real-page .cantidad-select{padding:8px 12px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.flujo-real-page .btn-icon{padding:8px;border:none;border-radius:6px;background:#ecf0f1;color:#7f8c8d;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.flujo-real-page .btn-icon:hover{background:#2980b9;color:#fff}.flujo-real-page .btn-icon svg{font-size:20px}.flujo-real-page .vista-selector{display:flex;background:#f8f9fa;border-radius:8px;padding:4px;gap:4px}.flujo-real-page .vista-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:#7f8c8d;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease}.flujo-real-page .vista-btn:hover{background:#ecf0f1;color:#2c3e50}.flujo-real-page .vista-btn.active{background:#2980b9;color:#fff}.flujo-real-page .vista-btn svg{font-size:18px}.flujo-real-page .vista-btn span{display:block}@media (max-width: 900px){.flujo-real-page .vista-btn span{display:none}}.flujo-real-page .resumen-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.flujo-real-page .resumen-card{background:#fff;border-radius:12px;padding:16px;display:flex;align-items:center;gap:14px;box-shadow:0 2px 8px #00000014}.flujo-real-page .resumen-card .card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.flujo-real-page .resumen-card .card-icon svg{font-size:24px;color:#fff}.flujo-real-page .resumen-card.saldo-inicial .card-icon{background:linear-gradient(135deg,#3498db,#2980b9)}.flujo-real-page .resumen-card.ingresos .card-icon{background:linear-gradient(135deg,#2ecc71,#27ae60)}.flujo-real-page .resumen-card.egresos .card-icon{background:linear-gradient(135deg,#e74c3c,#c0392b)}.flujo-real-page .resumen-card.saldo-final .card-icon{background:linear-gradient(135deg,#9b59b6,#8e44ad)}.flujo-real-page .card-content{display:flex;flex-direction:column;gap:4px}.flujo-real-page .card-label{font-size:12px;color:#7f8c8d;text-transform:uppercase;font-weight:500}.flujo-real-page .card-value{font-size:20px;font-weight:700;color:#2c3e50}.flujo-real-page .card-value.positivo{color:#27ae60}.flujo-real-page .card-value.negativo{color:#e74c3c}.flujo-real-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#7f8c8d}.flujo-real-page .loading-spinner{width:40px;height:40px;border:3px solid #ecf0f1;border-top-color:#2980b9;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.flujo-real-page .flujo-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.flujo-real-page .table-wrapper{overflow-x:auto}.flujo-real-page .flujo-table{width:100%;border-collapse:collapse;font-size:12px}.flujo-real-page .flujo-table th{background:#f8f9fa;padding:10px 8px;text-align:center;font-weight:600;color:#2c3e50;border-bottom:2px solid #ecf0f1;white-space:nowrap}.flujo-real-page .flujo-table .header-concepto{text-align:left;min-width:180px;position:sticky;left:0;background:#f8f9fa;z-index:10}.flujo-real-page .flujo-table .header-actual{min-width:100px}.flujo-real-page .flujo-table .header-periodo{min-width:90px}.flujo-real-page .flujo-table .header-total{min-width:100px;background:#e8f4fc;color:#2980b9}.flujo-real-page .periodo-header{display:flex;flex-direction:column;align-items:center;gap:2px}.flujo-real-page .periodo-header svg{font-size:14px;color:#7f8c8d}.flujo-real-page .periodo-header .periodo-fechas{font-size:12px;color:#2c3e50;font-weight:600;white-space:nowrap}.flujo-real-page .periodo-header .periodo-semana{font-size:10px;color:#7f8c8d;font-weight:400}.flujo-real-page .seccion-header td{background:#2c3e50;color:#fff;font-weight:600;padding:10px 12px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.flujo-real-page .seccion-header td svg{vertical-align:middle;margin-right:8px;font-size:16px}.flujo-real-page .seccion-header.disponibilidades td{background:#3498db}.flujo-real-page .seccion-header.ingresos td{background:#27ae60}.flujo-real-page .seccion-header.egresos td{background:#e74c3c}.flujo-real-page .seccion-header.saldo-final td{background:#8e44ad}.flujo-real-page .flujo-table td{padding:8px;border-bottom:1px solid #ecf0f1;text-align:center}.flujo-real-page .celda-nombre{text-align:left;font-weight:500;color:#2c3e50;position:sticky;left:0;background:#fff;z-index:5}.flujo-real-page .celda-valor{font-family:Monaco,Consolas,monospace;font-size:11px}.flujo-real-page .celda-valor.saldo{color:#2980b9;font-weight:600}.flujo-real-page .celda-valor.ingreso{color:#27ae60}.flujo-real-page .celda-valor.egreso{color:#e74c3c}.flujo-real-page .celda-valor.total{font-weight:700;background:#f8f9fa}.flujo-real-page .celda-valor.saldo-final{font-weight:700;font-size:12px}.flujo-real-page .celda-valor.saldo-final.positivo{color:#27ae60;background:#e8f8f0}.flujo-real-page .celda-valor.saldo-final.negativo{color:#e74c3c;background:#fdf2f2}.flujo-real-page .fila-subtotal td{font-weight:600;background:#f8f9fa;border-top:2px solid #ecf0f1}.flujo-real-page .fila-subtotal.disponibilidades td{background:#ebf5fb}.flujo-real-page .fila-subtotal.ingresos td{background:#e8f8f0}.flujo-real-page .fila-subtotal.egresos td{background:#fdf2f2}.flujo-real-page .fila-saldo-final td{font-weight:700;font-size:13px;background:#f5f0fa}.flujo-real-page .fila-saldo-final .celda-nombre{background:#f5f0fa;color:#8e44ad}@media (max-width: 1200px){.flujo-real-page .resumen-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.flujo-real-page .page-header{flex-direction:column;align-items:flex-start}.flujo-real-page .header-actions{width:100%;flex-wrap:wrap}.flujo-real-page .resumen-cards{grid-template-columns:1fr}}.gastos-estimados-page{padding:20px;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px;gap:20px}.page-header h1{color:#2ecc71;margin:0 0 5px}.page-subtitle{color:#7f8c8d;font-size:14px;margin:0}.header-actions{display:flex;gap:10px;align-items:center}.select-moneda{padding:8px 15px;border:1px solid #dfe6e9;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;background:#fff}.cambios-pendientes{background:#fff3cd;border:1px solid #ffc107;color:#856404;padding:10px 15px;border-radius:6px;margin-bottom:20px;font-size:13px}.loading,.error-message{text-align:center;padding:40px;font-size:16px}.error-message{color:#e74c3c;background:#fef0ef;border-radius:8px}.matriz-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.matriz-table{width:100%;border-collapse:collapse;min-width:800px}.matriz-table thead{background:#34495e;color:#fff}.matriz-table th{padding:12px 10px;text-align:center;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.matriz-table th.concepto-col{text-align:left;min-width:150px}.matriz-table th.mes-col{min-width:100px}.matriz-table th.total-col{background:#2c3e50;min-width:100px}.matriz-table tbody tr{border-bottom:1px solid #ecf0f1;transition:background .15s}.matriz-table tbody tr:hover{background:#f8f9fa}.matriz-table td{padding:8px 10px}.concepto-cell{font-weight:500;color:#2c3e50;font-size:13px}.valor-cell{text-align:center}.valor-cell.editado{background:#fff8e1}.input-valor{width:90px;padding:6px 8px;border:1px solid #dfe6e9;border-radius:4px;font-size:13px;text-align:right;font-family:Courier New,monospace;transition:all .2s}.input-valor:focus{outline:none;border-color:#2ecc71;box-shadow:0 0 0 2px #2ecc7133}.input-valor:disabled{background:#f5f5f5}.total-cell{text-align:right;font-weight:600;color:#27ae60;font-family:Courier New,monospace;font-size:13px;background:#f8f9fa}.matriz-table tfoot{background:#ecf0f1}.totales-row td{padding:12px 10px;font-size:13px}.total-mes-cell{text-align:center;font-weight:600;color:#e74c3c;font-family:Courier New,monospace}.total-general-cell{text-align:right;font-weight:700;color:#c0392b;font-family:Courier New,monospace;font-size:14px;background:#d5dbdb}.instrucciones{margin-top:20px;padding:15px;background:#e8f8f5;border-radius:8px;border-left:4px solid #2ecc71}.instrucciones p{margin:0;font-size:13px;color:#2c3e50}@media (max-width: 768px){.page-header{flex-direction:column}.input-valor{width:70px}}.reportes-page{padding:1.5rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-icon{font-size:1.75rem;color:var(--primary-color, #3b82f6)}.tabs-container{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color, #e5e7eb);padding-bottom:0}.tab-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-muted, #6b7280);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:-2px}.tab-button:hover{color:var(--text-primary, #1f2937);background:var(--bg-hover, #f3f4f6)}.tab-button.active{color:var(--primary-color, #3b82f6);border-bottom-color:var(--primary-color, #3b82f6)}.tab-button svg{font-size:1.25rem}.report-section{display:flex;flex-direction:column;gap:1.5rem}.filters-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:1.25rem}.filters-card h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937)}.filters-grid{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.375rem;min-width:150px}.filter-group label{font-size:.8125rem;font-weight:500;color:var(--text-secondary, #4b5563)}.filter-group select,.filter-group input[type=date]{padding:.5rem .75rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.875rem;background-color:var(--bg-input, #fff);color:var(--text-primary, #1f2937)}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.filter-actions{min-width:auto}.filter-actions .button{height:36px;white-space:nowrap}.results-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:1.25rem}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.results-header h3{margin:0;font-size:1.125rem;font-weight:600}.totals-row{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.total-card{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.5rem;background:var(--bg-subtle, #f9fafb);border-radius:8px;min-width:180px}.total-label{font-size:.75rem;font-weight:500;color:var(--text-muted, #6b7280);text-transform:uppercase;letter-spacing:.05em}.total-value{font-size:1.25rem;font-weight:700;color:var(--text-primary, #1f2937)}.total-count{font-size:.75rem;color:var(--text-muted, #6b7280)}.saldos-resumen{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.saldo-card{display:flex;flex-direction:column;gap:.25rem;padding:1rem;border-radius:8px;text-align:center}.saldo-inicial{background:var(--bg-subtle, #f3f4f6)}.saldo-ingresos{background:#10b9811a}.saldo-egresos{background:#ef44441a}.saldo-final{background:#3b82f61a}.saldo-label{font-size:.75rem;font-weight:500;color:var(--text-muted, #6b7280);text-transform:uppercase}.saldo-value{font-size:1.125rem;font-weight:700}.table-responsive{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border-color, #e5e7eb)}.table th{font-weight:600;color:var(--text-secondary, #4b5563);background:var(--bg-subtle, #f9fafb);font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em}.table tbody tr:hover{background:var(--bg-hover, #f9fafb)}.table .text-right{text-align:right}.table .text-success{color:var(--success-color, #10b981)}.table .text-danger{color:var(--danger-color, #ef4444)}.table code{font-size:.8125rem;padding:.125rem .375rem;background:var(--bg-subtle, #f3f4f6);border-radius:4px}.table-mayor .row-saldo-inicial,.table-mayor .row-saldo-final{background:var(--bg-subtle, #f3f4f6)}.table-mayor .row-saldo-inicial td,.table-mayor .row-saldo-final td{padding:1rem .75rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted, #6b7280)}.reportes-page .button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.reportes-page .button-primary{background:#3b82f6;color:#fff}.reportes-page .button-primary:hover:not(:disabled){background:#2563eb}.reportes-page .button-primary:disabled{opacity:.6;cursor:not-allowed}.reportes-page .button-secondary{background:#f3f4f6;color:#1f2937;border:1px solid #d1d5db}.reportes-page .button-secondary:hover{background:#e5e7eb}.badge{display:inline-block;padding:.25rem .5rem;font-size:.75rem;font-weight:500;border-radius:4px;margin-left:.5rem}.badge-usd{background:#22c55e1a;color:#16a34a}.badge-ars{background:#3b82f61a;color:#2563eb}.validacion-cell{width:80px}.btn-validar,.btn-validado{background:transparent;border:none;cursor:pointer;padding:.25rem;border-radius:4px;font-size:1.25rem;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.btn-validar{color:var(--text-muted, #9ca3af)}.btn-validar:hover{color:var(--success-color, #10b981);background:#10b9811a}.btn-validado{color:var(--success-color, #10b981)}.btn-validado:hover{background:#10b9811a}.row-validado{background-color:#10b9810d}.modal-content{background:var(--bg-card, #fff);border-radius:12px;width:100%;max-width:450px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content.modal-large{max-width:1100px!important;width:95%!important}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600}.modal-close{background:transparent;border:none;cursor:pointer;font-size:1.25rem;color:var(--text-muted, #6b7280);padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-hover, #f3f4f6);color:var(--text-primary, #1f2937)}.modal-body{padding:1.25rem}.modal-body p{margin:0 0 1rem;color:var(--text-secondary, #4b5563)}.modal-body .form-group{display:flex;flex-direction:column;gap:.375rem}.modal-body .form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary, #4b5563)}.modal-body .form-group textarea{padding:.625rem .75rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.875rem;resize:vertical;font-family:inherit}.modal-body .form-group textarea:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.validacion-detalle{background:var(--bg-subtle, #f9fafb);padding:1rem;border-radius:8px}.validacion-detalle p{margin:0 0 .5rem}.validacion-detalle p:last-child{margin-bottom:0}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border-color, #e5e7eb)}.reportes-page .button-danger{background:#ef4444;color:#fff}.reportes-page .button-danger:hover:not(:disabled){background:#dc2626}@media (max-width: 768px){.reportes-page{padding:1rem}.filters-grid{grid-template-columns:1fr}.tabs-container{flex-direction:column;gap:0}.tab-button{border-bottom:none;border-left:3px solid transparent;justify-content:flex-start}.tab-button.active{border-left-color:var(--primary-color, #3b82f6);border-bottom-color:transparent}.saldos-resumen{grid-template-columns:1fr 1fr}.results-header{flex-direction:column;align-items:flex-start;gap:1rem}}.permisos-page{padding:1.5rem;max-width:1000px;margin:0 auto}.permisos-page .button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.permisos-page .button-primary{background:#3b82f6;color:#fff}.permisos-page .button-primary:hover:not(:disabled){background:#2563eb}.permisos-page .button-primary:disabled{opacity:.6;cursor:not-allowed}.permisos-page .button-secondary{background:#f3f4f6;color:#1f2937;border:1px solid #d1d5db}.permisos-page .button-secondary:hover{background:#e5e7eb}.form-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:1.25rem;margin-bottom:1.5rem}.form-card h3{margin:0 0 1rem;font-size:1rem;font-weight:600}.form-grid{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:.375rem;flex:1;min-width:200px}.form-group label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary, #4b5563)}.form-group select{padding:.5rem .75rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.875rem;background-color:var(--bg-input, #fff);color:var(--text-primary, #1f2937)}.form-group select:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;gap:.5rem;min-width:auto}.permisos-list{display:flex;flex-direction:column;gap:1rem}.permiso-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.usuario-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--bg-subtle, #f9fafb);border-bottom:1px solid var(--border-color, #e5e7eb)}.usuario-info{display:flex;align-items:center;gap:.75rem}.usuario-icon{font-size:1.5rem;color:var(--text-muted, #6b7280)}.usuario-nombre{font-weight:600;color:var(--text-primary, #1f2937)}.usuario-username{display:block;font-size:.8125rem;color:var(--text-muted, #6b7280)}.badge{padding:.25rem .625rem;background:#3b82f61a;color:#2563eb;border-radius:9999px;font-size:.75rem;font-weight:500}.medios-list{padding:.5rem}.medio-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:6px;transition:background .15s ease}.medio-item:hover{background:var(--bg-hover, #f9fafb)}.medio-info{display:flex;align-items:center;gap:.5rem}.medio-info svg{color:var(--text-muted, #6b7280)}.medio-nombre{font-weight:500;color:var(--text-primary, #1f2937)}.medio-moneda{padding:.125rem .375rem;border-radius:4px;font-size:.6875rem;font-weight:600}.medio-moneda.ars{background:#3b82f61a;color:#2563eb}.medio-moneda.usd{background:#10b9811a;color:#059669}.btn-eliminar{background:transparent;border:none;cursor:pointer;padding:.375rem;border-radius:4px;color:var(--text-muted, #9ca3af);font-size:1.125rem;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.btn-eliminar:hover:not(:disabled){color:#ef4444;background:#ef44441a}.btn-eliminar:disabled{opacity:.5;cursor:not-allowed}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted, #6b7280);background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px}.empty-state svg{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state p{margin:0}.empty-state .hint{font-size:.875rem;margin-top:.5rem}@media (max-width: 768px){.permisos-page{padding:1rem}.page-header{flex-direction:column;align-items:stretch}.form-grid{flex-direction:column}.form-group{width:100%}.form-actions{justify-content:flex-end;width:100%}}.permisos-visibilidad-page{padding:1.5rem;max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.page-title{display:flex;align-items:center;gap:.75rem}.page-title h1{margin:0;font-size:1.5rem;font-weight:600}.page-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--text-muted, #6b7280)}.page-icon{font-size:2rem;color:var(--primary-color, #3b82f6)}.info-banner{display:flex;gap:1rem;padding:1rem 1.25rem;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:8px;margin-bottom:1.5rem;color:#1e40af}.info-banner svg{font-size:1.25rem;flex-shrink:0;margin-top:.125rem}.info-banner ul{margin:.5rem 0 0;padding-left:1.25rem;font-size:.875rem}.info-banner li{margin-bottom:.25rem}.permisos-container{display:flex;flex-direction:column;gap:1.5rem}.user-selector-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:1.25rem}.user-selector-card h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:600}.user-select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.9375rem;background-color:var(--bg-input, #fff);color:var(--text-primary, #1f2937)}.user-select:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.user-status{margin-top:1rem;padding:.75rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.status-all{background:#10b9811a;color:#059669}.status-restricted{background:#f59e0b1a;color:#d97706}.cajas-card{background:var(--bg-card, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.cajas-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #e5e7eb);background:var(--bg-subtle, #f9fafb)}.cajas-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1rem;font-weight:600}.cajas-actions{display:flex;align-items:center;gap:.5rem}.btn-link{background:none;border:none;color:#3b82f6;font-size:.8125rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px}.btn-link:hover{background:#3b82f61a}.separator{color:var(--border-color, #d1d5db)}.cajas-groups{padding:1rem 1.25rem}.moneda-group{margin-bottom:1.5rem}.moneda-group:last-child{margin-bottom:0}.moneda-title{margin:0 0 .75rem;padding:.375rem .75rem;border-radius:4px;font-size:.8125rem;font-weight:600;display:inline-block}.moneda-title.usd{background:#10b9811a;color:#059669}.moneda-title.ars{background:#3b82f61a;color:#2563eb}.cajas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.caja-checkbox{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;cursor:pointer;transition:all .15s ease;position:relative}.caja-checkbox:hover{border-color:#3b82f6;background:#3b82f605}.caja-checkbox.checked{border-color:#3b82f6;background:#3b82f614}.caja-checkbox input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#3b82f6}.caja-name{flex:1;font-weight:500;color:var(--text-primary, #1f2937);font-size:.875rem}.caja-tipo{font-size:.6875rem;color:var(--text-muted, #6b7280);text-transform:uppercase;letter-spacing:.05em}.check-icon{color:#3b82f6;font-size:1.25rem}.close-icon{color:#9ca3af;font-size:1.25rem}.save-bar{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-top:1px solid var(--border-color, #e5e7eb);background:var(--bg-subtle, #f9fafb);gap:1rem}.save-info{font-size:.875rem;color:var(--text-muted, #6b7280)}.button{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.button-primary{background:#3b82f6;color:#fff}.button-primary:hover:not(:disabled){background:#2563eb}.button-primary:disabled{opacity:.6;cursor:not-allowed}.loading-state{text-align:center;padding:3rem 1rem;color:var(--text-muted, #6b7280)}@media (max-width: 768px){.permisos-visibilidad-page{padding:1rem}.info-banner{flex-direction:column;gap:.5rem}.cajas-header{flex-direction:column;align-items:flex-start;gap:.75rem}.cajas-grid{grid-template-columns:1fr}.save-bar{flex-direction:column;align-items:stretch;text-align:center}.save-bar .button{width:100%;justify-content:center}}.extractos-bancarios-page{padding:1.5rem}.page-header{margin-bottom:1.5rem}.page-header h1{display:flex;align-items:center;gap:.5rem;margin:0 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.header-icon{color:var(--primary)}.page-description{color:var(--text-secondary);margin:0}.resumen-bars{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.resumen-bar{display:flex;align-items:center;gap:1.5rem;background:#fff;border-radius:8px;padding:.75rem 1rem;border:1px solid var(--border-color);cursor:pointer;transition:all .15s}.resumen-bar:hover{border-color:var(--primary);background:#fafbff}.resumen-bar.selected{border-color:var(--primary);background:#f0f7ff}.bar-banco{display:flex;align-items:center;gap:.5rem;min-width:200px}.bar-banco svg{font-size:1.25rem;color:var(--primary)}.banco-nombre{font-weight:600;font-size:.95rem}.moneda-badge{background:var(--gray-100);color:var(--text-secondary);padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600}.bar-stats{display:flex;gap:1rem;min-width:140px}.stat-item{font-size:.8rem;font-weight:500}.stat-item.pending{color:var(--warning)}.stat-item.success{color:var(--success)}.bar-montos{display:flex;gap:1.5rem;flex:1;justify-content:flex-end}.monto{font-size:.9rem;font-weight:600;font-family:SF Mono,Monaco,monospace;white-space:nowrap}.monto.credito{color:var(--success)}.monto.debito{color:var(--danger)}.monto.saldo{color:var(--primary);font-weight:700;min-width:160px;text-align:right}.btn-sync{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .15s;flex-shrink:0;font-size:.85rem;font-weight:500}.btn-sync:hover:not(:disabled){background:var(--primary-dark)}.btn-sync:disabled{opacity:.6;cursor:not-allowed}.btn-sync .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.conexiones-pendientes{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.conexion-pendiente-card{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,#fff9e6,#fff3cc);border:2px dashed #e6b800;border-radius:10px;gap:1rem}.conexion-info{display:flex;align-items:center;gap:.75rem}.conexion-info .bank-icon{font-size:1.5rem;color:#c90}.conexion-info .medio-nombre{font-weight:600;font-size:1rem;color:#805500}.conexion-info .connection-badge{background:#ffffffb3;padding:4px 10px;border-radius:4px;font-size:.8rem;color:#960;border:1px solid #e6b800}.conexion-status{display:flex;align-items:center;gap:1rem}.conexion-status .status-text{font-size:.85rem;color:#960;font-style:italic}.btn-sync-first{background:linear-gradient(135deg,#e6a800,#c90);padding:.6rem 1.25rem;font-weight:600;margin-top:0;width:auto}.btn-sync-first:hover:not(:disabled){background:linear-gradient(135deg,#c90,#b38600)}.filters-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem;padding:.75rem 1rem;background:#fff;border-radius:8px;margin-bottom:1rem;border:1px solid var(--border-color)}.filter-group{display:flex;flex-direction:column;gap:.2rem}.filter-group label{display:flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.filter-group select,.filter-group input{padding:.4rem .6rem;border:1px solid var(--border-color);border-radius:4px;min-width:130px;font-size:.85rem;background:#fff}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2196f31a}.filter-group input[type=date]{min-width:120px}.table-container{background:#fff;border-radius:8px;overflow:hidden}.loading-state,.empty-state{padding:3rem;text-align:center;color:var(--text-secondary)}.empty-state .empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.3}.empty-state .hint{font-size:.85rem;margin-top:.5rem}.extractos-table{width:100%;border-collapse:collapse;font-size:.85rem}.extractos-table th,.extractos-table td{padding:.4rem .6rem;text-align:left;border-bottom:1px solid var(--border-color);vertical-align:middle}.extractos-table th{background:var(--gray-50);font-weight:600;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;padding:.5rem .6rem}.extractos-table tbody tr{transition:background .1s}.extractos-table tbody tr:hover{background:#f8fafc}.extractos-table tbody tr.row-clasificado{background:#f0fdf4}.extractos-table tbody tr.row-clasificado:hover{background:#dcfce7}.fecha-col{white-space:nowrap;width:85px;color:var(--text-secondary)}.descripcion-col{max-width:250px}.descripcion-text{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.importe-col{text-align:right;min-width:150px;width:160px;white-space:nowrap;font-family:SF Mono,Monaco,monospace;font-weight:600;font-size:.85rem}.importe.credito{color:var(--success)}.importe.debito{color:var(--danger)}.select-col{width:180px}.inline-select{width:100%;padding:.3rem .5rem;font-size:.8rem;border:1px solid var(--border-color);border-radius:4px;background:#fff;cursor:pointer}.inline-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2196f31a}.inline-select:disabled{background:var(--gray-50);cursor:not-allowed}.select-col .subconcepto-autocomplete{font-size:.8rem}.select-col .subconcepto-autocomplete input{padding:.3rem .5rem;font-size:.8rem}.estado-col{width:70px;text-align:center}.estado-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600}.estado-badge.pendiente{background:#fef3c7;color:#92400e}.estado-badge.clasificado{background:#d1fae5;color:#065f46}.estado-badge.procesado{background:#dbeafe;color:#1e40af}.estado-badge.ignorado{background:var(--gray-100);color:var(--text-secondary)}.btn-action{width:32px;height:32px;border:none;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;margin:0 2px;transition:all .2s}.btn-clasificar{background:var(--success-bg, #d4edda);color:var(--success)}.btn-clasificar:hover{background:var(--success);color:#fff}.btn-ignorar{background:var(--gray-100);color:var(--text-secondary)}.btn-ignorar:hover{background:var(--danger);color:#fff}.btn-editar{background:var(--info-bg, #cce5ff);color:var(--primary)}.btn-editar:hover{background:var(--primary);color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem;border-top:1px solid var(--border-color)}.pagination button{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;background:#fff;cursor:pointer;transition:all .2s}.pagination button:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{font-size:.9rem;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.25rem}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;line-height:1}.btn-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.extracto-preview{background:var(--gray-50);padding:1rem;border-radius:4px;margin-bottom:1.5rem}.preview-row{display:flex;margin-bottom:.5rem}.preview-row:last-child{margin-bottom:0}.preview-row .label{width:100px;font-weight:600;color:var(--text-secondary)}.preview-row .credito{color:var(--success);font-weight:600}.preview-row .debito{color:var(--danger);font-weight:600}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.25rem;font-weight:600;font-size:.9rem}.form-group select{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem}.btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--gray-200);color:var(--text-primary)}.btn-secondary:hover{background:var(--gray-300)}.extractos-table tr.tipo-credito{background:linear-gradient(90deg,rgba(40,167,69,.05) 0%,transparent 20%)}.extractos-table tr.tipo-debito{background:linear-gradient(90deg,rgba(220,53,69,.05) 0%,transparent 20%)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}.header-left{flex:1}.header-actions{display:flex;gap:.5rem}.btn-config{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;box-shadow:0 2px 8px #667eea59;transition:all .2s ease}.btn-config:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea73}.btn-config:active{transform:translateY(0)}.config-modal{max-width:750px;border-radius:12px;box-shadow:0 20px 60px #0000004d}.config-modal .modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0;padding:1.25rem 1.5rem}.config-modal .modal-header h2{display:flex;align-items:center;gap:.5rem;color:#fff;font-size:1.2rem}.config-modal .modal-header .btn-close{color:#fff;opacity:.8}.config-modal .modal-header .btn-close:hover{opacity:1;color:#fff}.config-modal .modal-body{padding:1.5rem;background:#f8f9fc}.config-list{margin-bottom:1.5rem}.config-list h3{font-size:.95rem;margin:0 0 1rem;color:#374151;display:flex;align-items:center;gap:.5rem}.config-list h3:before{content:"";display:inline-block;width:4px;height:16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px}.config-card{background:#fff;border-radius:8px;padding:1rem;margin-bottom:.75rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb}.config-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.config-card-title{display:flex;align-items:center;gap:.75rem}.config-card-title .medio-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 10px;border-radius:4px;font-weight:600;font-size:.85rem}.config-card-title .connection-name{color:#6b7280;font-size:.85rem}.config-card-actions{display:flex;gap:.5rem}.config-card-actions .btn-action{width:36px;height:36px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.config-card-actions .btn-editar{background:#667eea1a;color:#667eea;border:1px solid rgba(102,126,234,.2)}.config-card-actions .btn-editar:hover{background:#667eea;color:#fff;border-color:#667eea}.config-card-actions .btn-eliminar{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.config-card-actions .btn-eliminar:hover{background:#ef4444;color:#fff;border-color:#ef4444}.config-card-details{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:.75rem;background:#f9fafb;border-radius:6px;margin-bottom:.75rem}.config-detail{display:flex;flex-direction:column;gap:2px}.detail-label{font-size:.7rem;color:#9ca3af;text-transform:uppercase;font-weight:600}.detail-value{font-size:.8rem;color:#374151;font-family:monospace}.config-card-footer{display:flex;justify-content:flex-end}.sync-info{font-size:.75rem;color:#9ca3af}.btn-eliminar{background:#ef44441a;color:#ef4444}.btn-eliminar:hover{background:#ef4444;color:#fff}.config-form{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #00000014}.config-form h3{font-size:.95rem;margin:0 0 1.25rem;color:#374151;display:flex;align-items:center;gap:.5rem}.config-form h3:before{content:"";display:inline-block;width:4px;height:16px;background:linear-gradient(135deg,#10b981,#059669);border-radius:2px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.5rem}.form-section-title{font-weight:600;font-size:.85rem;color:#6b7280;margin:1.25rem 0 .5rem;padding-top:1.25rem;border-top:1px solid #e5e7eb;text-transform:uppercase;letter-spacing:.03em}.form-hint{font-size:.8rem;color:#9ca3af;margin:0 0 1rem}.config-form .form-group{margin-bottom:1rem}.config-form .form-group label{display:block;font-size:.8rem;font-weight:600;color:#4b5563;margin-bottom:.4rem}.config-form .form-group input[type=text],.config-form .form-group select{width:100%;padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;background:#fff;color:#374151;transition:all .2s}.config-form .form-group input[type=text]:focus,.config-form .form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.config-form .form-group select:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid #e5e7eb}.form-actions .btn-secondary{background:#f3f4f6;color:#4b5563;border:1px solid #d1d5db}.form-actions .btn-secondary:hover{background:#e5e7eb}.form-actions .btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;box-shadow:0 2px 6px #10b9814d}.form-actions .btn-primary:hover{box-shadow:0 4px 10px #10b98166}.btn:disabled{opacity:.6;cursor:not-allowed}.config-empty{text-align:center;padding:2rem;color:#9ca3af}.config-empty-icon{font-size:2.5rem;margin-bottom:.5rem;opacity:.5}.loading-headers{display:flex;align-items:center;gap:.5rem;padding:1rem;margin:1rem 0;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:8px;color:#667eea;font-size:.9rem}.loading-headers .spinning{animation:spin 1s linear infinite}.no-headers-warning{padding:1rem;margin:1rem 0;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#dc2626;font-size:.9rem}@media (max-width: 768px){.page-header{flex-direction:column}.header-actions{width:100%}.btn-config{width:100%;justify-content:center}.form-row{grid-template-columns:1fr}.config-modal{max-width:95%;margin:1rem}}:root{--color-primary: #CC3334;--color-primary-dark: #A02829;--color-primary-light: #E55455;--color-secondary: #000000;--color-accent: #CC3334;--color-text: #1a1a1a;--color-text-secondary: #666666;--color-text-light: #999999;--color-bg: #ffffff;--color-bg-secondary: #f8f9fa;--color-bg-tertiary: #e9ecef;--color-sidebar-bg: #2c3e50;--color-sidebar-text: #ecf0f1;--color-sidebar-text-secondary: #bdc3c7;--color-sidebar-hover: #34495e;--color-sidebar-active: #1a252f;--color-border: #dee2e6;--color-divider: #ced4da;--color-border-light: #e9ecef;--color-success: #2ecc71;--color-warning: #f39c12;--color-error: #e74c3c;--color-info: #3498db;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--shadow-xl: 0 12px 24px rgba(0, 0, 0, .18);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: "Courier New", Courier, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-tooltip: 1070}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:1.5;color:var(--color-text);background-color:var(--color-bg-secondary);min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}button,.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}button:disabled,.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;box-shadow:var(--shadow-sm)}.button-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark),#8a1f1f);transform:translateY(-2px);box-shadow:var(--shadow-md)}.button-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.button-secondary{background-color:#fff;color:var(--color-text);border:2px solid var(--color-border);box-shadow:var(--shadow-sm)}.button-secondary:hover:not(:disabled){background-color:var(--color-bg-secondary);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.button-ghost{background-color:transparent;color:var(--color-text)}.button-ghost:hover:not(:disabled){background-color:var(--color-bg-secondary);color:var(--color-primary)}.button-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}.button-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}input,textarea,select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background-color:#fff;transition:border-color var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary)}input::placeholder,textarea::placeholder{color:var(--color-text-light)}label{display:block;margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}table{width:100%;border-collapse:collapse;background-color:#fff;border-radius:var(--radius-md);overflow:hidden}th,td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}th{background-color:var(--color-bg-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}tbody tr:hover{background-color:var(--color-bg-secondary)}tbody tr:last-child td{border-bottom:none}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-secondary)}.text-small{font-size:var(--font-size-sm)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-xl)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mt-4{margin-top:var(--spacing-xl)}
