@import "https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&display=swap";:root{--color-bg:#0f1117;--color-surface:#161b27;--color-surface-2:#1e2535;--color-border:#2a3042;--color-text:#e2e8f0;--color-text-muted:#64748b;--color-accent:#8b5cf6;--color-accent-hover:#7c3aed;--color-success:#22c55e;--color-danger:#ef4444;--color-warning:#f59e0b;--color-info:#3b82f6;--radius:6px;--radius-lg:10px;--font:"Geist", -apple-system, BlinkMacSystemFont, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}img{max-width:100%}#root{width:100%;min-height:100vh}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1;transition:background .2s,color .2s,border-color .2s,opacity .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn--primary:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.btn--danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn--danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.btn--ghost{color:var(--color-text-muted);border-color:var(--color-border);background:0 0}.btn--ghost:hover:not(:disabled){color:var(--color-text);border-color:var(--color-text-muted);background:#ffffff0d}.btn--success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn--icon{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0;padding:.4rem .5rem;font-size:.8rem}.btn--icon:hover{color:var(--color-text);background:#ffffff0d}.btn--icon-danger:hover{color:var(--color-danger);border-color:var(--color-danger)}.btn--icon-success:hover{color:var(--color-success);border-color:var(--color-success)}.btn--sm{padding:.35rem .7rem;font-size:.8rem}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.form-row{gap:.75rem;display:grid}.form-row--2{grid-template-columns:1fr 1fr}.form-row--3{grid-template-columns:1fr 1fr 1fr}.form-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600}.form-input,.form-select,.form-textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);width:100%;padding:.55rem .8rem;font-size:.9rem;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent);outline:none}.form-input:read-only{opacity:.6;cursor:default}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}.form-select option{background:var(--color-surface-2)}.form-unidad-dual{align-items:stretch;gap:.5rem;display:flex}.form-unidad-dual .form-unidad__primaria{flex:1 1 0;min-width:0}.form-unidad-dual .form-unidad__cantidad{text-align:center;flex:0 0 4.25rem;width:4.25rem;min-width:3.75rem;padding-left:.4rem;padding-right:.4rem}.form-unidad-dual .form-select.form-unidad__contenido{flex:0 5rem;min-width:3.75rem;max-width:5.5rem}.form-textarea{resize:vertical;min-height:80px}.form-acciones{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:1rem;display:flex}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-right{text-align:right}.font-mono{font-variant-numeric:tabular-nums}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem}.seccion-toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.seccion-toolbar--space{justify-content:space-between}.filtros-grupo{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.separador{background:var(--color-border);height:1px;margin:1.25rem 0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.app-layout{background:var(--color-bg);min-height:100vh;display:flex}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;width:240px;height:100vh;transition:width .25s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.app-layout--colapsado .sidebar{width:60px}.sidebar__header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.2rem 1rem;display:flex}.sidebar__logo{align-items:center;gap:.6rem;display:flex;overflow:hidden}.sidebar__logo-icon{color:var(--color-accent);flex-shrink:0;font-size:1.4rem;line-height:1}.sidebar__logo-texto{color:var(--color-text);white-space:nowrap;letter-spacing:-.02em;font-size:1rem;font-weight:700}.sidebar__toggle{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius);background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:1rem;transition:color .2s,background .2s;display:flex}.sidebar__toggle:hover{color:var(--color-text);background:var(--color-bg)}.sidebar__nav{flex-direction:column;flex:1;gap:.25rem;padding:.75rem .5rem;display:flex;overflow-y:auto}.sidebar__link{border-radius:var(--radius);color:var(--color-text-muted);white-space:nowrap;align-items:center;gap:.75rem;padding:.6rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s,background .2s;display:flex;overflow:hidden}.sidebar__link:hover{color:var(--color-text);background:#ffffff0d}.sidebar__link--activo{color:var(--color-accent);background:#8b5cf61f}.sidebar__link-icon{flex-shrink:0;font-size:1.1rem;line-height:1}.sidebar__link-label{text-overflow:ellipsis;overflow:hidden}.sidebar__footer{border-top:1px solid var(--color-border);flex-shrink:0;padding:.75rem 1rem}.sidebar__version{color:var(--color-text-muted);margin:0;font-size:.72rem}.main-content{flex:1;max-width:calc(100vw - 240px);min-height:100vh;margin-left:240px;padding:2rem;transition:margin-left .25s}.app-layout--colapsado .main-content{max-width:calc(100vw - 60px);margin-left:60px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.75rem;display:flex}.page-header__titulo{color:var(--color-text);letter-spacing:-.02em;margin:0;font-size:1.5rem;font-weight:700}.page-header__sub{color:var(--color-text-muted);margin:.2rem 0 0;font-size:.85rem}.badge{text-transform:capitalize;letter-spacing:.03em;white-space:nowrap;border-radius:999px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-block}.badge--success{color:#4ade80;background:#22c55e26}.badge--danger{color:#f87171;background:#ef444426}.badge--info{color:#60a5fa;background:#3b82f626}.badge--warning{color:#facc15;background:#eab30826}.badge--muted{color:#94a3b8;background:#94a3b81a}.badge--accent{color:#a78bfa;background:#8b5cf626}.badge--purple{color:#c084fc;background:#a855f726}.badge--default{color:#cbd5e1;background:#94a3b826}.dashboard__stats{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--color-border);height:2px;position:absolute;top:0;left:0;right:0}.stat-card--accent:before{background:var(--color-accent)}.stat-card--info:before{background:var(--color-info)}.stat-card--success:before{background:var(--color-success)}.stat-card--danger:before{background:var(--color-danger)}.stat-card__label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-size:.78rem;font-weight:600}.stat-card__valor{color:var(--color-text);letter-spacing:-.03em;font-size:2rem;font-weight:700;line-height:1}.stat-card__sub{color:var(--color-text-muted);margin-top:.35rem;font-size:.78rem}.dashboard__grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.dashboard__movimientos{grid-column:1/-1}.dashboard__seccion-titulo{color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;font-weight:600;display:flex}.dashboard__seccion-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dashboard__seccion-dot--success{background:var(--color-success)}.dashboard__seccion-dot--danger{background:var(--color-danger)}.dashboard__lista-cuentas{flex-direction:column;gap:.6rem;list-style:none;display:flex}.dashboard__cuenta-item{background:var(--color-bg);border-radius:var(--radius);border:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:.5rem;padding:.6rem .75rem;display:flex}.dashboard__cuenta-item>div{align-items:center;gap:.5rem;min-width:0;display:flex}.dashboard__cuenta-nombre{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.dashboard__mov-lista{flex-direction:column;gap:0;list-style:none;display:flex}.dashboard__mov-item{border-bottom:1px solid var(--color-border);align-items:center;gap:.75rem;padding:.65rem 0;display:flex}.dashboard__mov-item:last-child{border-bottom:none}.dashboard__mov-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dashboard__mov-dot--haber{background:var(--color-success)}.dashboard__mov-dot--debe{background:var(--color-danger)}.dashboard__mov-info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.dashboard__mov-concepto{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.dashboard__mov-cuenta{color:var(--color-text-muted);font-size:.75rem}.dashboard__mov-derecha{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.1rem;display:flex}.toast-container{z-index:9999;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:var(--radius);opacity:0;align-items:center;gap:.6rem;min-width:260px;max-width:380px;padding:.75rem 1.2rem;font-size:.9rem;font-weight:500;transition:all .3s;display:flex;transform:translate(2rem);box-shadow:0 4px 20px #0006}.toast--visible{opacity:1;transform:translate(0)}.toast--exito{background:var(--color-success);color:#fff}.toast--error{background:var(--color-danger);color:#fff}.toast--info{background:var(--color-accent);color:#fff}.toast__icono{flex-shrink:0;font-size:1rem;font-weight:700}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;width:100%;max-height:90vh;animation:.25s slideUp;display:flex;box-shadow:0 20px 60px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(1.5rem)}to{opacity:1;transform:translateY(0)}}.modal--sm{max-width:420px}.modal--md{max-width:620px}.modal--lg{max-width:860px}.modal--xl{max-width:1100px}.modal__header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.2rem 1.5rem;display:flex}.modal__titulo{color:var(--color-text);margin:0;font-size:1.1rem;font-weight:600}.modal__cerrar{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;padding:.3rem .5rem;font-size:1rem;line-height:1;transition:color .2s,background .2s}.modal__cerrar:hover{color:var(--color-text);background:var(--color-bg)}.modal__body{flex:1;padding:1.5rem;overflow-y:auto}.confirm__mensaje{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:.95rem;line-height:1.6}.confirm__acciones{justify-content:flex-end;gap:.75rem;display:flex}.buscador{align-items:center;display:flex;position:relative}.buscador__icono{color:var(--color-text-muted);pointer-events:none;-webkit-user-select:none;user-select:none;font-size:1.1rem;position:absolute;left:.75rem}.buscador__input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);width:100%;color:var(--color-text);min-width:220px;padding:.5rem 2.2rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.buscador__input:focus{border-color:var(--color-accent);outline:none}.buscador__limpiar{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.2rem;font-size:.8rem;line-height:1;transition:color .2s;position:absolute;right:.5rem}.buscador__limpiar:hover{color:var(--color-text)}.tabla-wrapper{border-radius:var(--radius);border:1px solid var(--color-border);overflow-x:auto}.tabla{border-collapse:collapse;width:100%;font-size:.875rem}.tabla__th{background:var(--color-bg);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.tabla__th--sortable{cursor:pointer;transition:color .2s}.tabla__th--sortable:hover{color:var(--color-text)}.tabla__th--right,.tabla__td--right{text-align:right}.tabla__th--center,.tabla__td--center{text-align:center}.tabla__th--acciones,.tabla__td--acciones{text-align:center;white-space:nowrap;width:1%}.tabla__orden{color:var(--color-text-muted);font-size:.7rem}.tabla__tr{transition:background .15s}.tabla__tr:hover{background:#ffffff08}.tabla__td{border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle;padding:.75rem 1rem}.tabla__tr:last-child .tabla__td{border-bottom:none}.tabla__vacio{color:var(--color-text-muted);text-align:center;padding:2rem;font-size:.9rem}.tabla__acciones-grupo{justify-content:center;gap:.4rem;display:flex}.tarjeta-producto{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;gap:.6rem;padding:1.1rem;transition:border-color .2s;display:flex}.tarjeta-producto:hover{border-color:var(--color-accent)}.tarjeta-producto--inactiva{opacity:.55}.tarjeta-producto__header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.tarjeta-producto__badges{flex-wrap:wrap;gap:.35rem;display:flex}.tarjeta-producto__acciones{flex-shrink:0;gap:.3rem;display:flex}.tarjeta-producto__nombre{color:var(--color-text);font-size:.95rem;font-weight:600;line-height:1.3}.tarjeta-producto__desc{color:var(--color-text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;line-height:1.4;display:-webkit-box;overflow:hidden}.tarjeta-producto__meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.tarjeta-producto__unidad{color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:99px;padding:.1rem .5rem;font-size:.75rem}.tarjeta-producto__proveedor{color:var(--color-text-muted);font-size:.75rem}.tarjeta-producto__precios{background:var(--color-bg);border-radius:var(--radius);grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:.25rem;padding:.6rem;display:grid}.tarjeta-producto__precio-item{flex-direction:column;align-items:center;gap:.15rem;display:flex}.tarjeta-producto__precio-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:.68rem;font-weight:600}.tarjeta-producto__precio-valor{color:var(--color-text);font-size:.82rem;font-weight:500}.productos-page{max-width:1400px}.productos-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.btn--active{border-color:var(--color-accent);color:var(--color-accent)}.cuentas-page{max-width:1400px}.estado-cuenta__toolbar-btns{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.estado-cuenta__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1.5rem;display:flex}.estado-cuenta__badges{flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem;display:flex}.estado-cuenta__nombre{color:var(--color-text);margin-bottom:.4rem;font-size:1.2rem;font-weight:700}.estado-cuenta__meta{color:var(--color-text-muted);flex-wrap:wrap;gap:1rem;font-size:.8rem;display:flex}.estado-cuenta__saldo-box{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;flex-shrink:0;min-width:160px;padding:1rem 1.5rem}.estado-cuenta__saldo-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.3rem;font-size:.72rem;font-weight:600}.estado-cuenta__saldo-valor{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.estado-cuenta__saldo-hint{color:var(--color-text-muted);margin-top:.2rem;font-size:.72rem}.calc-page{max-width:1300px;padding:1.5rem}.calc-layout{grid-template-columns:1fr 360px;align-items:start;gap:1.5rem;display:grid}.calc-panel{flex-direction:column;gap:1.25rem;display:flex}.calc-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem}.calc-section__header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.calc-section__titulo{color:var(--color-text);margin:0 0 1rem;font-size:.9rem;font-weight:600}.calc-section__header .calc-section__titulo{margin:0}.calc-items{flex-direction:column;gap:.5rem;margin-bottom:.75rem;display:flex}.calc-item{grid-template-columns:1fr 140px auto;align-items:center;gap:.5rem;display:grid}.calc-item__monto{text-align:right}.calc-subtotal{border-top:1px solid var(--color-border);color:var(--color-text);justify-content:space-between;align-items:center;padding:.5rem .25rem;font-size:.875rem;font-weight:600;display:flex}.calc-subtotal--secondary{color:var(--color-text-muted);border-top:none;padding-top:.25rem;font-size:.8rem;font-weight:400}.calc-resultado{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;position:sticky;top:1.5rem}.calc-resultado__titulo{color:var(--color-text);border-bottom:1px solid var(--color-border);word-break:break-word;margin:0 0 1.25rem;padding-bottom:.75rem;font-size:1rem;font-weight:700}.calc-resultado__breakdown{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.calc-resultado__fila{color:var(--color-text-muted);justify-content:space-between;align-items:center;font-size:.875rem;display:flex}.calc-resultado__fila--total{color:var(--color-text);border-top:2px solid var(--color-border);margin-top:.25rem;padding-top:.5rem;font-size:1rem;font-weight:700}.calc-resultado__referencia{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:1.25rem;padding:.75rem 1rem}.calc-resultado__margenes{margin-bottom:1.25rem}.calc-resultado__margenes-titulo{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.75rem;font-size:.8rem;font-weight:600}.calc-resultado__margen-grid{grid-template-columns:repeat(5,1fr);gap:.4rem;display:grid}.calc-resultado__margen-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);text-align:center;cursor:pointer;padding:.5rem .25rem;transition:border-color .15s,background .15s}.calc-resultado__margen-item:hover{border-color:var(--color-primary)}.calc-resultado__margen-item--activo{border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 10%, transparent)}.calc-resultado__margen-pct{color:var(--color-text);font-size:.75rem;font-weight:600;display:block}.calc-resultado__margen-precio{color:var(--color-text-muted);margin-top:.15rem;font-size:.7rem;display:block}.calc-resultado__custom{border-top:1px solid var(--color-border);padding-top:1rem}.calc-resultado__custom-row{align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.calc-resultado__custom-precio{color:var(--color-success);margin-left:auto;font-size:1.1rem;font-weight:700}@media (width<=900px){.calc-layout{grid-template-columns:1fr}.calc-resultado{position:static}.calc-page{padding:1rem}}
