:root{font-family:Segoe UI,Helvetica Neue,Arial,sans-serif;--bg-primary: #0a0a0f;--bg-secondary: #111118;--bg-card: #16161f;--bg-card-hover: #1c1c28;--accent: #6366f1;--accent-light: #818cf8;--accent-glow: rgba(99, 102, 241, .15);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #475569;--border: rgba(255, 255, 255, .06);--border-active: rgba(99, 102, 241, .4);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--shadow-glow: 0 0 40px rgba(99, 102, 241, .08)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}#root{min-height:100vh}.erp-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.erp-sidebar{background:linear-gradient(180deg,#111118,#0d0d14);color:var(--text-primary);padding:24px 16px;border-right:1px solid var(--border);box-shadow:1px 0 20px #6366f10a;position:relative;z-index:10;display:flex;flex-direction:column}.erp-brand{padding:8px 10px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.erp-brand-logo{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,#4f46e5 100%);flex-shrink:0;box-shadow:0 0 16px #6366f166}.erp-brand-text{display:flex;flex-direction:column}.erp-brand-kicker{margin:0;font-size:10px;color:var(--text-muted);letter-spacing:.6px;text-transform:uppercase}.erp-brand h1{margin:2px 0 0;font-size:17px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.erp-nav{display:flex;flex-direction:column;gap:4px;margin-top:18px}.erp-nav-item{position:relative;width:100%;text-align:left;border:none;background:transparent;color:var(--text-secondary);border-radius:8px;padding:10px 12px 10px 16px;font-size:13.5px;cursor:pointer;transition:background .18s ease,color .18s ease;overflow:hidden}.erp-nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleX(0);transform-origin:left;width:3px;height:60%;border-radius:0 3px 3px 0;background:var(--accent);transition:transform .18s ease}.erp-nav-item:hover{background:#ffffff0a;color:var(--text-primary)}.erp-nav-item:hover:before{transform:translateY(-50%) scaleX(1)}.erp-nav-item.is-active{background:var(--accent-glow);color:var(--accent-light);font-weight:600}.erp-nav-item.is-active:before{transform:translateY(-50%) scaleX(1);background:var(--accent)}.erp-main{display:flex;flex-direction:column;gap:20px;padding:26px;position:relative;overflow:hidden;background:var(--bg-primary)}.erp-bg-parallax{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}.erp-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.06}.erp-blob--1{width:500px;height:500px;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);top:-100px;right:-50px}.erp-blob--2{width:400px;height:400px;background:radial-gradient(circle,#8b5cf6 0%,transparent 70%);bottom:-80px;left:100px}.erp-blob--3{width:300px;height:300px;background:radial-gradient(circle,#06b6d4 0%,transparent 70%);top:40%;right:20%;opacity:.04}.erp-main>*:not(.erp-bg-parallax){position:relative;z-index:1}.erp-header{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.erp-header-left{display:flex;flex-direction:column;gap:4px}.erp-header-kicker{margin:0;color:var(--text-muted);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.erp-header h2{margin:0;font-size:26px;font-weight:700;color:var(--text-primary);line-height:1.15;position:relative}.erp-header h2:after{content:"";display:block;margin-top:4px;height:2px;width:0;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--accent-light));animation:underline-grow .4s ease forwards}@keyframes underline-grow{0%{width:0}to{width:100%}}.erp-card-grid{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(240px,1fr))}.erp-card-span-full{grid-column:1 / -1}.erp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:18px;min-height:138px;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.erp-card:hover{transform:translateY(-2px);border-color:var(--border-active);box-shadow:var(--shadow-glow)}.erp-card h3{margin:0 0 12px;font-size:15px;font-weight:600;color:var(--text-secondary);letter-spacing:.2px}.erp-card p{margin:0;color:var(--text-secondary);line-height:1.45}.tf-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.tf-input,.tf-select{padding:9px 12px;border:1px solid rgba(255,255,255,.08);border-radius:8px;font-size:14px;color:var(--text-primary);background:#ffffff0a;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;outline:none;width:100%}.tf-input::placeholder{color:var(--text-muted)}.tf-input:focus,.tf-select:focus{border-color:var(--border-active);box-shadow:0 0 0 3px var(--accent-glow);background:#ffffff0f}.tf-input:disabled,.tf-select:disabled{opacity:.45;cursor:not-allowed}.tf-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.tf-select option{background:var(--bg-secondary);color:var(--text-primary)}.tf-submit{padding:10px 20px;background:linear-gradient(135deg,var(--accent) 0%,#4f46e5 100%);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:filter .15s ease,transform .15s ease;align-self:flex-start;letter-spacing:.1px}.tf-submit:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.02)}.tf-submit:disabled{opacity:.5;cursor:not-allowed}.tf-refresh-btn{padding:6px 14px;border:1px solid var(--border);border-radius:8px;background:#ffffff0a;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.tf-refresh-btn:hover{background:#ffffff14;border-color:var(--border-active);color:var(--text-primary)}.transaction-form form{display:flex;flex-direction:column;gap:12px;margin-top:4px}.tf-field{display:flex;flex-direction:column;gap:5px}.tf-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tf-field--amount .tf-input{font-variant-numeric:tabular-nums;font-weight:600}.tf-textarea{resize:vertical;font-family:inherit;line-height:1.45}.tf-feedback{margin:0;padding:9px 14px;border-radius:8px;font-size:13px;line-height:1.4}.tf-feedback--error{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#fca5a5}.tf-feedback--success{background:#10b9811a;border:1px solid rgba(16,185,129,.25);color:#6ee7b7}.movement-badge,.appt-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.movement-badge--posted{background:#10b98126;color:#34d399;box-shadow:0 0 8px #10b98126}.movement-badge--reversed{background:#ef44441f;color:#f87171;box-shadow:0 0 8px #ef44441a}.movement-list{min-height:auto}.movement-empty{color:var(--text-muted);font-style:italic;margin-top:8px}.movement-items{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}.movement-item{border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;background:#ffffff04;transition:border-color .18s ease,background .18s ease}.movement-item:hover{border-color:var(--border-active);background:#6366f10a}.movement-item-header{display:flex;align-items:center;gap:8px}.movement-date{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.movement-description{margin:0;font-size:14px;font-weight:500;color:var(--text-primary)}.movement-lines{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:3px;overflow:hidden}.movement-line{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.movement-line-account{flex:1}.movement-line-side{font-size:11px;font-weight:600;text-transform:uppercase;padding:1px 6px;border-radius:4px}.movement-line-side--debit{background:#6366f126;color:var(--accent-light)}.movement-line-side--credit{background:#10b9811f;color:#34d399}.movement-line-amount{font-variant-numeric:tabular-nums;font-weight:500;color:var(--text-primary)}.balance-card{display:flex;flex-direction:column;gap:12px}.balance-loading{display:flex;flex-direction:column;gap:10px;margin-top:4px}.balance-skeleton{height:14px;border-radius:6px;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:skeleton-shimmer 1.6s ease infinite}.balance-skeleton--lg{height:36px;width:70%;border-radius:8px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.balance-saldo-caja{display:flex;flex-direction:column;gap:2px;padding:10px 0 12px;border-bottom:1px solid var(--border)}.balance-saldo-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.balance-saldo-amount{font-size:34px;font-weight:700;color:var(--text-primary);line-height:1.1;font-variant-numeric:tabular-nums;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.balance-metrics{display:flex;flex-direction:column;gap:6px}.balance-metric{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.balance-metric-label{font-size:13px;color:var(--text-secondary)}.balance-metric-value{font-size:14px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.balance-metric-value.is-muted{color:var(--danger)}.skeleton-item{border-radius:6px;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff17,#ffffff0a 75%);background-size:200% 100%;animation:skeleton-shimmer 1.6s ease infinite}.skeleton-wrap{display:flex;flex-direction:column;gap:8px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.page-header-left{display:flex;flex-direction:column;gap:4px}.page-header-kicker{margin:0;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.page-header-title{margin:0;font-size:24px;font-weight:700;color:var(--text-primary);position:relative;display:inline-block}.page-header-title:after{content:"";display:block;margin-top:4px;height:2px;width:0;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--accent-light));animation:underline-grow .5s .1s ease forwards}.appt-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.appt-list-header h3{margin:0}.appt-items{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}.appt-item{border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:4px;background:#ffffff04;transition:border-color .18s ease}.appt-item:hover{border-color:var(--border-active)}.appt-item-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.appt-date{font-size:13px;color:var(--text-muted)}.appt-customer{margin:0;font-size:15px;font-weight:600;color:var(--text-primary)}.appt-meta{display:flex;gap:10px;flex-wrap:wrap}.appt-meta-item{font-size:12px;color:var(--text-secondary);background:#ffffff0f;border-radius:6px;padding:2px 8px}.appt-badge--pending{background:#f59e0b26;color:#fbbf24;box-shadow:0 0 8px #f59e0b1a}.appt-badge--confirmed{background:#10b9811f;color:#34d399;box-shadow:0 0 8px #10b9811a}.appt-badge--cancelled{background:#ffffff0f;color:var(--text-muted)}.appt-badge--loan-active{background:#6366f126;color:var(--accent-light);box-shadow:0 0 8px #6366f11f}.appt-badge--loan-paid{background:#10b9811f;color:#34d399}.appt-badge--loan-default{background:#ef44441f;color:#f87171}.loan-type{margin:0;font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.loan-metrics{display:flex;flex-direction:column;gap:4px;margin-top:4px}.loan-metric{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:13px;color:var(--text-secondary)}.inventory-table{min-height:auto}.inv-table-wrap{overflow-x:auto;margin-top:10px}.inv-table{width:100%;border-collapse:collapse;font-size:14px}.inv-th{text-align:left;padding:7px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);border-bottom:1px solid var(--border)}.inv-th--num{text-align:right}.inv-tr:hover{background:#ffffff08}.inv-tr--zero{background:#ef44440a}.inv-tr--zero:hover{background:#ef444412}.inv-td{padding:8px 10px;color:var(--text-primary);border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums}.inv-td--num{text-align:right}.module-loading{margin:0;color:var(--text-muted);font-style:italic}.budget-badge--pending{background:#ffffff0f;color:var(--text-secondary)}.budget-badge--approved{background:#10b9811f;color:#34d399}.budget-badge--rejected{background:#ef44441f;color:#f87171}.budget-badge--expired{background:#f59e0b1f;color:#fbbf24}.restored-badge--available{background:#6366f126;color:var(--accent-light)}.restored-badge--reserved{background:#f59e0b1f;color:#fbbf24}.restored-badge--sold{background:#10b9811f;color:#34d399}.price-inline-input{width:100%;min-width:90px;padding:5px 8px;font-size:13px}.price-input-wrap{display:flex;flex-direction:column;gap:2px;align-items:flex-end}.price-save-btn{padding:5px 10px;font-size:12px;white-space:nowrap}.price-margin{font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}.price-margin--positive{color:#34d399}.price-margin--negative{color:var(--danger)}.price-margin--neutral{color:var(--text-muted)}.price-row-error{font-size:11px;color:var(--danger)}.price-row-success{font-size:11px;color:var(--success)}.budget-meta-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-top:2px}.budget-total{font-size:15px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.budget-controls{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.budget-status-select{font-size:13px;padding:5px 8px;flex:1;min-width:120px;max-width:200px}.budget-items-detail{margin-top:10px;border-top:1px solid var(--border);padding-top:10px}.budget-items-table{font-size:13px}.budget-lines-section{display:flex;flex-direction:column;gap:8px;margin-top:4px}.budget-lines-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.budget-line-row{display:grid;grid-template-columns:1fr 80px 110px 32px;gap:8px;align-items:end}.budget-line-desc,.budget-line-qty,.budget-line-price{min-width:0}.budget-line-remove{display:flex;align-items:flex-end;padding-bottom:1px}.budget-remove-btn{width:28px;height:34px;border:1px solid var(--border);border-radius:8px;background:#ffffff0a;color:var(--text-muted);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease,border-color .15s ease}.budget-remove-btn:hover:not(:disabled){background:#ef44441f;border-color:#ef44444d;color:var(--danger)}.budget-remove-btn:disabled{opacity:.4;cursor:not-allowed}.budget-total-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:10px 0 4px;border-top:1px solid var(--border);margin-top:4px}.budget-total-amount{font-size:18px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.restored-sell-section{margin-top:10px;display:flex;flex-direction:column;gap:8px}.restored-sell-toggle{align-self:flex-start}.restored-sell-form{border-top:1px solid var(--border);padding-top:10px;display:flex;flex-direction:column;gap:10px}.erp-card-grid--dashboard,.erp-card-grid--module{grid-template-columns:repeat(2,minmax(240px,1fr))}@media(max-width:920px){.erp-shell{grid-template-columns:1fr}.erp-sidebar{border-right:none;border-bottom:1px solid var(--border)}.erp-nav{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr))}.erp-card-grid,.erp-card-grid--dashboard,.erp-card-grid--module,.tf-row{grid-template-columns:1fr}.budget-line-row{grid-template-columns:1fr 60px 90px 32px;gap:6px}}.erp-user-section{margin-top:auto;padding-top:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.erp-user-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.erp-user-name{margin:0;font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.erp-user-role{margin:0;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.erp-logout-btn{flex-shrink:0;padding:5px 12px;border:1px solid var(--border);border-radius:7px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.erp-logout-btn:hover{background:#ef444414;border-color:#ef44444d;color:#f87171}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:24px}.login-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:0 8px 40px #0006,var(--shadow-glow);display:flex;flex-direction:column;gap:24px}.login-brand{display:flex;align-items:center;gap:12px}.login-brand-logo{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--accent) 0%,#4f46e5 100%);flex-shrink:0;box-shadow:0 0 20px #6366f166}.login-brand-kicker{margin:0 0 2px;font-size:10px;color:var(--text-muted);letter-spacing:.6px;text-transform:uppercase}.login-brand-title{margin:0;font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.login-tabs{display:flex;gap:4px;background:#ffffff08;border-radius:10px;padding:4px;border:1px solid var(--border)}.login-tab-btn{flex:1;padding:8px 12px;border:none;border-radius:7px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease}.login-tab-btn.is-active{background:var(--accent-glow);color:var(--accent-light);font-weight:600}.login-tab-btn:hover:not(.is-active){background:#ffffff0a;color:var(--text-primary)}.login-fields{display:flex;flex-direction:column;gap:14px}.login-input-wrap{position:relative}.login-input-wrap .tf-input{padding-right:40px}.login-eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:color .15s ease}.login-eye-btn:hover{color:var(--text-secondary)}.tf-input--error{border-color:#ef444480!important;box-shadow:0 0 0 3px #ef444414!important}.login-field-error{margin:0;font-size:11.5px;color:#f87171}.login-submit-btn{width:100%;padding:11px 20px;font-size:14.5px;align-self:stretch;text-align:center;margin-top:4px}.login-switch-text{margin:0;font-size:13px;color:var(--text-muted);text-align:center}.login-link-btn{background:transparent;border:none;color:var(--accent-light);font-size:13px;cursor:pointer;padding:0;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s ease,color .15s ease}.login-link-btn:hover{color:#a5b4fc;text-decoration-color:#a5b4fc}
