@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&display=swap";:root{--font-sans: "Montserrat", system-ui, -apple-system, sans-serif;--font-display: "Montserrat", sans-serif;--bg-primary: #f4f6fa;--bg-secondary: #ffffff;--bg-tertiary: #e9edf5;--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(0, 0, 0, .08);--glass-hover: rgba(0, 0, 0, .04);--accent-primary: #009de9;--accent-primary-hover: #0082c3;--accent-secondary: #ffe6c3;--accent-secondary-hover: #f3d8b5;--text-primary: #1f2937;--text-secondary: #4b5563;--text-muted: #9ca3af;--border-color: rgba(0, 0, 0, .08);--danger: #ef4444;--danger-hover: #dc2626;--success: #10b981;--warning: #f59e0b;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .15), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px}*{box-sizing:border-box;margin:0;padding:0;font-family:var(--font-sans)}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;background-image:radial-gradient(at 0% 0%,rgba(0,157,233,.06) 0px,transparent 50%),radial-gradient(at 100% 100%,rgba(255,230,195,.15) 0px,transparent 50%),radial-gradient(at 50% 50%,rgba(0,157,233,.03) 0px,transparent 50%);background-attachment:fixed}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.7}}.animate-fade-in{animation:fadeIn .4s cubic-bezier(.16,1,.3,1) forwards}.pulsing{animation:pulse-subtle 2s infinite ease-in-out}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;position:relative}.login-card{width:100%;max-width:440px;background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:0 20px 40px #00000014,0 0 40px #009de90a;animation:fadeIn .6s cubic-bezier(.16,1,.3,1) forwards}.login-logo{width:110px;height:110px;margin:0 auto 1.5rem;display:block;object-fit:contain;border-radius:var(--radius-lg);box-shadow:0 8px 30px #009de940}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.login-subtitle{color:var(--text-secondary);font-size:.9rem}.spinner{width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;min-height:100vh;background-color:var(--bg-primary);position:relative}.sidebar{width:280px;background:linear-gradient(180deg,var(--accent-primary) 0%,#0079b4 100%);color:#fff;display:flex;flex-direction:column;transition:width .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 20px #0000000f;position:relative;flex-shrink:0;z-index:10}.sidebar.collapsed{width:85px}.sidebar-brand{padding:.75rem 1.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border-bottom:2px solid rgba(255,255,255,.7);white-space:nowrap;min-height:100px;background:#0009}.sidebar-logo{width:65px;height:65px;object-fit:contain;transition:all .3s ease}.sidebar.collapsed .sidebar-logo{width:40px;height:40px}.sidebar-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:#fff;transition:opacity .2s ease}.sidebar.collapsed .sidebar-title{opacity:0;display:none}.sidebar-menu{list-style:none;padding:.75rem .5rem;display:flex;flex-direction:column;gap:.2rem}.sidebar-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem;color:#ffffffd9;text-decoration:none;border-radius:var(--radius-md);font-weight:600;font-size:.88rem;cursor:pointer;transition:all .2s ease;white-space:nowrap;border:none;background:transparent;width:100%;text-align:left}.sidebar-item:hover{background:#ffffff14;color:#fff}.sidebar-item.active{background:#ffffff29;color:#fff;font-weight:700;box-shadow:inset 0 0 0 1px #ffffff0d}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;color:currentColor}.sidebar-label{transition:opacity .2s ease}.sidebar.collapsed .sidebar-label{opacity:0;display:none}.sidebar-toggle-btn{position:absolute;top:115px;right:-14px;width:28px;height:28px;background:#0079b4;border:2px solid #f4f6fa;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:15;box-shadow:0 2px 8px #00000026;font-size:.75rem;transition:all .2s ease}.sidebar-toggle-btn:hover{background:var(--accent-primary);transform:scale(1.1)}.sidebar-footer{margin-top:auto;padding:.75rem .5rem;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:.5rem}.sidebar-user-profile{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;white-space:nowrap;overflow:hidden}.user-avatar-circle{width:40px;height:40px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;color:#fff;font-size:1rem}.user-details{display:flex;flex-direction:column;transition:opacity .2s ease}.sidebar.collapsed .user-details{opacity:0;display:none}.user-name{font-weight:700;font-size:.95rem;color:#fff}.user-role{font-size:.75rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.sidebar-footer-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#ffffffd9;background:#ffffff14;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;width:100%;transition:all .2s ease;white-space:nowrap}.sidebar-footer-btn:hover{background:#ffffff29;color:#fff}.sidebar.collapsed .sidebar-footer-btn{justify-content:center;padding:.75rem 0}.sidebar.collapsed .sidebar-footer-btn span:not(.sidebar-icon){display:none}.main-content-wrapper{flex-grow:1;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden}.main-header{background:#fff;border-bottom:1px solid var(--border-color);padding:1.25rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:9;box-shadow:0 2px 10px #00000005}.header-user-info{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.95rem}.mobile-menu-toggle{display:none}.sidebar-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a59;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:99;animation:fadeInBackdrop .2s ease-out;display:none}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}@media(max-width:1024px){.sidebar-backdrop{display:block}.sidebar{position:fixed!important;left:0;top:0;bottom:0;z-index:100!important;transform:translate(0);transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed{transform:translate(-100%);width:280px!important}.sidebar-toggle-btn{display:none!important}.mobile-menu-toggle{display:inline-flex!important;align-items:center;justify-content:center;background:transparent;border:none;color:var(--accent-primary);cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:background .2s}.mobile-menu-toggle:hover{background:#009de914}.main-header{padding:1rem 1.25rem!important}main{padding:1rem 1.25rem!important}.metrics-grid{grid-template-columns:repeat(2,1fr)!important}.detail-row-inputs{flex-direction:column;align-items:stretch!important;gap:.75rem}.detail-row-inputs .form-group{width:100%!important}}@media(max-width:600px){.metrics-grid{grid-template-columns:1fr!important}.search-bar-container{flex-direction:column;align-items:stretch!important;gap:.5rem}.btn-adjust{width:100%;justify-content:center}.modal-overlay{padding:1.5rem .5rem .5rem;align-items:flex-start}.modal-content{max-height:95vh;border-radius:var(--radius-lg);margin-top:0;animation:fadeIn .3s cubic-bezier(.16,1,.3,1) forwards}.login-card{padding:1.75rem!important}}@keyframes slideUpModal{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(min-width:769px){.mobile-only{display:none!important}}@media(max-width:768px){.desktop-only,.btn-refresh{display:none!important}.metric-card{padding:.5rem .75rem!important;gap:.1rem!important}.metric-title{font-size:.65rem!important}.metric-value{font-size:1.15rem!important}.budget-mobile-card{box-shadow:var(--shadow-sm)!important;border-color:#0000000d!important}}.app-container{display:flex;flex-direction:column;min-height:100vh}.header{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.logo-section{display:flex;align-items:center;gap:.75rem}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent-secondary),var(--accent-primary));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-family:var(--font-display);font-size:1.25rem;box-shadow:0 0 20px #6366f14d}.logo-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.025em;background:linear-gradient(to right,#ffffff,var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-actions{display:flex;align-items:center;gap:1rem}.glass-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-xl);transition:all .3s cubic-bezier(.16,1,.3,1)}.glass-card:hover{border-color:#ffffff1f;box-shadow:0 30px 60px #00000040}.main-content{flex:1;padding:2rem;max-width:1600px;width:100%;margin:0 auto;display:grid;grid-template-columns:280px 1fr;gap:2rem}@media(max-width:1024px){.main-content{grid-template-columns:1fr}}.sidebar{display:flex;flex-direction:column;gap:1.5rem}.sidebar-title{font-family:var(--font-display);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding-left:.5rem}.sheet-list{display:flex;flex-direction:column;gap:.5rem}.sheet-btn{background:transparent;border:1px solid transparent;color:var(--text-secondary);text-align:left;padding:.75rem 1rem;border-radius:var(--radius-md);font-weight:500;font-size:.95rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease;width:100%}.sheet-btn:hover{background:var(--glass-hover);color:var(--text-primary);transform:translate(4px)}.sheet-btn.active{background:#6366f126;border-color:#6366f14d;color:#a5b4fc}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);border:1px solid transparent}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-primary-hover);box-shadow:0 0 15px #10b98166;transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--glass-hover);border-color:#ffffff26}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover);box-shadow:0 0 15px #ef444466;transform:translateY(-1px)}.table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color);background:#0a0c1080}.db-table{width:100%;border-collapse:collapse;text-align:left;font-size:.9rem}.db-table th{background:var(--bg-secondary);color:var(--text-secondary);font-weight:600;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);letter-spacing:.02em}.db-table td{padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-primary);vertical-align:middle}.db-table tr:hover td{background:#ffffff05}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.badge-success{background:#10b98126;color:#34d399;border:1px solid rgba(16,185,129,.3)}.badge-indigo{background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.3)}.badge-warning{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.badge-danger{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.form-label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.form-input{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--text-primary);font-size:.95rem;transition:all .2s ease;width:100%}.form-input::placeholder{color:var(--text-muted);opacity:.8}.form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #009de926;background:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a59;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem}.modal-content{width:100%;max-width:550px;max-height:90vh;display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;animation:fadeIn .3s cubic-bezier(.16,1,.3,1) forwards}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600}.modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:var(--radius-sm)}.modal-close:hover{background:var(--glass-hover);color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;flex-grow:1}.modal-footer{padding:1.25rem 1.5rem;background:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem;flex-shrink:0}.stock-screen-container{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:1200px;margin:-1rem auto 0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1.25rem}.metric-card{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 1.25rem}.metric-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.metric-value{font-family:var(--font-display);font-size:1.4rem;font-weight:800;color:var(--accent-primary)}.search-bar-container{display:flex;gap:.75rem;align-items:center;padding:.5rem 1rem;margin-bottom:1.25rem}.search-input-wrapper{position:relative;flex-grow:1}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted);pointer-events:none}.search-input{padding:.45rem 1rem .45rem 2.25rem;font-size:.875rem;background:#fff!important;color:var(--text-primary)!important;border:1px solid var(--border-color)}.search-input::placeholder{color:var(--text-muted);opacity:.8}.search-input:focus{background:#fff!important;color:var(--text-primary)!important}.btn-refresh{padding:.625rem;width:38px;height:38px;min-width:38px;aspect-ratio:1 / 1}.btn-adjust{height:38px;display:inline-flex;align-items:center}.stock-loading-state,.stock-error-state,.empty-stock-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;text-align:center;color:var(--text-secondary);font-weight:500}.stock-loading-state .spinner{border-width:3px;border-top-color:var(--accent-primary);width:2rem;height:2rem}.brand-group-row td{background:#e0f2fe!important;color:#0369a1!important;font-weight:700;font-size:.85rem;padding:.5rem 1rem!important;letter-spacing:.03em;border-bottom:1px solid rgba(3,105,161,.15)}.stock-table-card{background:#fff!important;padding:0!important;overflow:hidden}.stock-table-card .table-container{background:#fff!important;border:none;border-radius:0;max-height:calc(100vh - 235px);overflow-y:auto}.stock-table-card .db-table th{position:sticky;top:0;z-index:10;background:#f8fafc!important;color:var(--text-secondary)!important;border-bottom:1px solid rgba(0,0,0,.06)!important;box-shadow:inset 0 -1px #0000000f;padding:.5rem .65rem!important;font-size:.8rem;white-space:nowrap}.stock-table-card .db-table td{color:var(--text-primary)!important;border-bottom:1px solid rgba(0,0,0,.04)!important;padding:.45rem .65rem!important;font-size:.8rem;white-space:nowrap}.stock-table-card .db-table tr:hover td{background:#009de905!important}.btn-group-toggle{display:flex;gap:.5rem;width:100%}.btn-toggle-type{flex:1;padding:.625rem;font-weight:600;text-align:center;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);transition:all .2s ease;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.25rem}.btn-toggle-type:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-toggle-ingreso.active{background:var(--success)!important;color:#fff!important;border-color:var(--success)!important;box-shadow:0 0 10px #10b98133}.btn-toggle-egreso.active{background:var(--danger)!important;color:#fff!important;border-color:var(--danger)!important;box-shadow:0 0 10px #ef444433}.select-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")!important;background-repeat:no-repeat!important;background-position:right 1rem center!important;background-size:1em!important;padding-right:2.5rem!important}.toast-container{position:fixed;bottom:2rem;right:2rem;z-index:2000;display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;border-radius:var(--radius-md);box-shadow:0 10px 25px #00000026;max-width:420px;animation:slideUp .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes slideUp{0%{transform:translateY(1.5rem);opacity:0}to{transform:translateY(0);opacity:1}}.toast-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fca5a5}.toast-icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center}.toast-message-text{font-size:.9rem;font-weight:600;line-height:1.4;flex-grow:1}.toast-close-btn{background:transparent;border:none;color:currentColor;opacity:.6;cursor:pointer;font-size:.9rem;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:opacity .2s ease}.toast-close-btn:hover{opacity:1}.detail-row-inputs{display:flex;gap:.5rem;align-items:flex-end;background:var(--bg-secondary);padding:.75rem;border-radius:var(--radius-md);margin-top:.5rem;border:1px dashed var(--border-color)}.detail-row-inputs .form-group{margin-bottom:0}.btn-delete-row{background:transparent;border:none;color:var(--danger);cursor:pointer;font-weight:700;padding:.25rem .5rem;border-radius:4px;font-size:1.1rem;line-height:1}.btn-delete-row:hover{background:#ef44441a}.proveedor-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;max-height:200px;overflow-y:auto;background:#fff;border:1px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:var(--radius-md);margin-top:2px}.proveedor-dropdown-item{padding:.625rem 1rem;cursor:pointer;transition:background .15s ease;color:var(--text-primary);text-align:left}.proveedor-dropdown-item:hover{background:var(--glass-hover)}.proveedor-dropdown-no-results{padding:.625rem 1rem;color:var(--text-muted);text-align:center}.mini-table th,.mini-table td{padding:.5rem .75rem!important}.full-screen-modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important;border:none!important}@media(max-width:768px){.metrics-grid{grid-template-columns:repeat(2,1fr)!important;gap:.5rem!important;margin-bottom:1rem!important}.search-bar-container{margin-bottom:1rem!important}.presupuesto-modal{height:95vh!important;max-height:95vh!important;width:98vw!important;padding:.5rem!important}.presupuesto-split-layout{flex-direction:column!important;overflow-y:auto!important;flex:1!important}.presupuesto-left-panel{width:100%!important;border-right:none!important;border-bottom:1px solid var(--border-color)!important;overflow-y:visible!important;flex-shrink:0!important;padding:.5rem .5rem 1rem!important}.presupuesto-right-panel{width:100%!important;overflow-y:visible!important;flex-shrink:0!important;padding:1rem .5rem .5rem!important}.presupuesto-table-wrapper{flex:none!important;overflow-y:visible!important;max-height:none!important}}
