:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{min-height:100svh}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.login-page{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 20px 60px #00000059,0 4px 16px #0003}.login-header{text-align:center;margin-bottom:2rem}.login-icon{color:#fff;background:linear-gradient(135deg,#0f3460,#533483);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 1rem;display:flex}.login-icon svg{width:32px;height:32px}.login-header h1{color:#1a1a2e;letter-spacing:-.3px;margin:0 0 .35rem;font-size:1.35rem;font-weight:700;line-height:1.3}.login-header p{color:#6b7280;margin:0;font-size:.875rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.field-group{flex-direction:column;gap:.375rem;display:flex}.field-group label{color:#374151;letter-spacing:.1px;font-size:.85rem;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#9ca3af;pointer-events:none;flex-shrink:0;width:18px;height:18px;transition:color .2s;position:absolute;left:.85rem}.input-wrapper input{color:#111827;box-sizing:border-box;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:.7rem .85rem .7rem 2.6rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s,background .2s}.input-wrapper input::placeholder{color:#9ca3af;font-size:.875rem}.input-wrapper input:focus{background:#fff;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601f}.input-wrapper input:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:#0f3460}.field-group.has-error .input-wrapper input{background:#fff5f5;border-color:#ef4444}.field-group.has-error .input-wrapper input:focus{box-shadow:0 0 0 3px #ef44441f}.field-error{color:#ef4444;align-items:center;gap:.3rem;font-size:.78rem;font-weight:500;animation:.15s ease-out slideIn;display:flex}.field-error svg{flex-shrink:0;width:13px;height:13px}@keyframes slideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.btn-login{color:#fff;letter-spacing:.2px;cursor:pointer;background:linear-gradient(135deg,#0f3460,#533483);border:none;border-radius:10px;margin-top:.5rem;padding:.8rem;font-size:.95rem;font-weight:600;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 14px #0f346066}.btn-login:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #0f346073}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.input-wrapper input:disabled{opacity:.6;cursor:not-allowed}.btn-login-inner{justify-content:center;align-items:center;gap:.5rem;display:flex}.btn-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-error{color:#b91c1c;background:#fff5f5;border:1.5px solid #ef4444;border-radius:10px;align-items:center;gap:.5rem;padding:.7rem 1rem;font-size:.85rem;font-weight:500;animation:.15s ease-out slideIn;display:flex}.login-error svg{color:#ef4444;flex-shrink:0;width:16px;height:16px}.cold-start-alert{background:#fffbeb;border:1.5px solid #f59e0b;border-radius:10px;align-items:flex-start;gap:.65rem;padding:.8rem 1rem;animation:.2s ease-out slideIn;display:flex}.cold-start-alert svg{color:#d97706;flex-shrink:0;width:18px;height:18px;margin-top:1px}.cold-start-alert p{color:#92400e;margin:0;font-size:.82rem;line-height:1.5}.cold-start-alert strong{color:#78350f;margin-bottom:.2rem;font-size:.85rem;font-weight:700;display:block}.dashboard-layout{background:#f1f5f9;min-height:100vh;font-family:system-ui,Segoe UI,Roboto,sans-serif;display:flex}.sidebar{background:linear-gradient(#1a1a2e 0%,#16213e 60%,#0f3460 100%);flex-direction:column;flex-shrink:0;width:240px;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:.65rem;padding:1.5rem 1.25rem 1.25rem;display:flex}.brand-icon{color:#c084fc;background:#ffffff1f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.brand-icon svg{width:20px;height:20px}.brand-name{color:#f1f5f9;letter-spacing:.2px;white-space:nowrap;font-size:.9rem;font-weight:700}.sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto}.sidebar-nav ul{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.nav-item{color:#fff9;cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:10px;align-items:center;gap:.7rem;width:100%;padding:.65rem .85rem;font-size:.875rem;font-weight:500;transition:background .18s,color .18s;display:flex}.nav-item:hover{color:#f1f5f9;background:#ffffff14}.nav-item.active{color:#c084fc;background:#c084fc2e;font-weight:600}.nav-icon{flex-shrink:0;align-items:center;width:20px;height:20px;display:flex}.nav-icon svg{width:18px;height:18px}.sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;gap:.65rem;padding:1rem .75rem;display:flex}.user-info{align-items:center;gap:.6rem;padding:0 .25rem;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#533483,#c084fc);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex}.user-name{color:#ffffffbf;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.btn-logout{color:#fca5a5;cursor:pointer;background:#ef444414;border:1px solid #ef44444d;border-radius:10px;align-items:center;gap:.6rem;width:100%;padding:.6rem .85rem;font-size:.85rem;font-weight:500;transition:background .18s,border-color .18s,color .18s;display:flex}.btn-logout:hover{color:#fecaca;background:#ef44442e;border-color:#ef44448c}.btn-logout svg{flex-shrink:0;width:16px;height:16px}.main-content{flex:1;min-width:0;overflow-y:auto}.home-view{max-width:1100px;padding:2rem 2.25rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.page-header h1{color:#1e293b;letter-spacing:-.4px;margin:0 0 .3rem;font-size:1.6rem;font-weight:700}.page-header p{color:#64748b;margin:0;font-size:.9rem}.page-date{color:#94a3b8;white-space:nowrap;text-transform:capitalize;padding-top:.25rem;font-size:.8rem}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem;display:grid}.summary-card{border-radius:14px;align-items:flex-start;gap:1rem;padding:1.5rem 1.5rem 1.4rem;display:flex;box-shadow:0 1px 4px #00000012,0 4px 16px #0000000f}.card-pending{background:#fff;border-left:4px solid #f59e0b}.card-sales{background:#fff;border-left:4px solid #10b981}.card-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.card-pending .card-icon{color:#d97706;background:#fef3c7}.card-sales .card-icon{color:#059669;background:#d1fae5}.card-icon svg{width:22px;height:22px}.card-body{flex-direction:column;gap:.2rem;display:flex}.card-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:.78rem;font-weight:600}.card-value{color:#1e293b;letter-spacing:-.5px;font-size:1.8rem;font-weight:700;line-height:1.1}.card-sub{color:#94a3b8;font-size:.78rem}.table-section{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #00000012,0 4px 16px #0000000f}.table-header{border-bottom:1px solid #f1f5f9;padding:1.25rem 1.5rem 1rem}.table-header h2{color:#1e293b;letter-spacing:-.2px;margin:0;font-size:1rem;font-weight:700}.presupuestos-table{border-collapse:collapse;width:100%;font-size:.875rem}.presupuestos-table thead tr{background:#f8fafc}.presupuestos-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:.75rem 1.5rem;font-size:.75rem;font-weight:700}.presupuestos-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.9rem 1.5rem}.presupuestos-table tbody tr:last-child td{border-bottom:none}.presupuestos-table tbody tr:hover td{background:#f8fafc}.cell-folio{font-family:ui-monospace,Consolas,monospace;font-size:.8rem;font-weight:600;color:#64748b!important}.cell-concepto{color:#475569!important}.cell-total{white-space:nowrap;font-weight:700;color:#1e293b!important}.badge{white-space:nowrap;letter-spacing:.2px;border-radius:999px;align-items:center;padding:.25rem .7rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-presupuesto{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.bottom-nav{display:none}.placeholder-view{justify-content:center;align-items:center;min-height:70vh;padding:2rem;display:flex}.placeholder-box{text-align:center;color:#94a3b8;max-width:280px}.placeholder-box svg{opacity:.45;width:52px;height:52px;margin-bottom:1rem}.placeholder-box h2{color:#64748b;margin:0 0 .4rem;font-size:1.15rem;font-weight:700}.placeholder-box p{margin:0;font-size:.875rem}@media (width<=768px){.sidebar{display:none}.main-content{padding-bottom:calc(60px + env(safe-area-inset-bottom,0px))}.bottom-nav{z-index:200;padding:0 .25rem;padding-bottom:env(safe-area-inset-bottom,0px);background:linear-gradient(#1a1a2e 0%,#16213e 100%);border-top:1px solid #ffffff14;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #00000059}.bottom-nav-btn{color:#ffffff80;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.2rem;min-height:56px;padding:.6rem .2rem;transition:color .15s;display:flex}.bottom-nav-btn.active{color:#c084fc}.bottom-nav-btn.active .bottom-nav-icon{filter:drop-shadow(0 0 4px #c084fc99)}.bottom-nav-logout{color:#fca5a5b3}.bottom-nav-logout:hover{color:#fca5a5}.bottom-nav-icon{justify-content:center;align-items:center;width:22px;height:22px;display:flex}.bottom-nav-icon svg{width:20px;height:20px}.bottom-nav-label{letter-spacing:.1px;white-space:nowrap;font-size:.62rem;font-weight:600}.home-view{padding:1.25rem .85rem}.page-header{margin-bottom:1.25rem}.page-header h1{font-size:1.25rem}.page-date{display:none}.cards-grid{gap:.75rem;margin-bottom:1.25rem}.table-section{border-radius:10px}.table-header{padding:.9rem 1rem .75rem}.presupuestos-table thead{display:none}.presupuestos-table,.presupuestos-table tbody{display:block}.presupuestos-table tbody tr{border-bottom:1px solid #f1f5f9;grid-template-columns:1fr auto;grid-template-areas:"folio estado""cliente cliente""concepto concepto""total total";gap:.2rem .5rem;padding:.85rem 1rem;display:grid}.presupuestos-table tbody tr:last-child{border-bottom:none}.presupuestos-table td{border:none;padding:0;font-size:.875rem}.presupuestos-table td[data-label=Folio]{grid-area:folio;font-size:.75rem}.presupuestos-table td[data-label=Estado]{grid-area:estado;justify-self:end}.presupuestos-table td[data-label=Cliente]{color:#1e293b;grid-area:cliente;font-weight:600}.presupuestos-table td[data-label=Concepto]{color:#64748b;grid-area:concepto;font-size:.82rem}.presupuestos-table td[data-label=Total]{color:#0f3460;grid-area:total;margin-top:.2rem;font-size:1rem;font-weight:700}}.catalogo-view{max-width:1100px;padding:2rem 2.25rem}.catalogo-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;display:flex}.catalogo-title h1{color:#1e293b;letter-spacing:-.4px;margin:0 0 .3rem;font-size:1.6rem;font-weight:700}.catalogo-title p{color:#64748b;margin:0;font-size:.9rem}.btn-agregar{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#0f3460,#533483);border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;transition:opacity .18s,transform .15s,box-shadow .18s;display:inline-flex;box-shadow:0 4px 14px #0f346059}.btn-agregar:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 18px #0f346066}.btn-agregar:active{transform:translateY(0)}.btn-agregar svg{flex-shrink:0;width:18px;height:18px}.catalogo-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #00000012,0 4px 16px #0000000f}.catalogo-toolbar{border-bottom:1px solid #f1f5f9;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.search-wrapper{flex:1;align-items:center;min-width:200px;max-width:360px;display:flex;position:relative}.search-icon{color:#94a3b8;pointer-events:none;width:16px;height:16px;position:absolute;left:.75rem}.search-input{color:#1e293b;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:.55rem .85rem .55rem 2.25rem;font-size:.875rem;transition:border-color .18s,box-shadow .18s,background .18s}.search-input::placeholder{color:#94a3b8}.search-input:focus{background:#fff;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601a}.result-count{color:#94a3b8;white-space:nowrap;font-size:.8rem}.table-wrapper{overflow-x:auto}.materiales-table{border-collapse:collapse;width:100%;font-size:.875rem}.materiales-table thead tr{background:#f8fafc}.materiales-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:.75rem 1.25rem;font-size:.72rem;font-weight:700}.materiales-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.85rem 1.25rem}.materiales-table tbody tr:last-child td{border-bottom:none}.materiales-table tbody tr:hover td{background:#f8fafc}.cell-codigo{white-space:nowrap;font-family:ui-monospace,Consolas,monospace;font-size:.8rem;font-weight:600;color:#64748b!important}.cell-desc{font-weight:500;color:#1e293b!important}.badge-unidad{color:#475569;white-space:nowrap;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.empty-row{text-align:center;color:#94a3b8;font-size:.9rem;padding:2.5rem!important}.modal-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#0f172a8c;justify-content:center;align-items:center;padding:1rem;animation:.15s ease-out backdropIn;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border-radius:16px;width:100%;max-width:480px;animation:.2s ease-out cardIn;overflow:hidden;box-shadow:0 25px 60px #0000004d,0 8px 24px #00000026}.modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem 1rem;display:flex}.modal-header h2{color:#1e293b;margin:0;font-size:1rem;font-weight:700}.modal-close{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:background .15s,color .15s;display:flex}.modal-close:hover{color:#1e293b;background:#e2e8f0}.modal-close svg{width:14px;height:14px}.modal-body{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem;display:flex}.modal-row{gap:.85rem;display:flex}.modal-row .modal-field{flex:1}.modal-field{flex-direction:column;gap:.35rem;display:flex}.modal-field label{color:#374151;font-size:.8rem;font-weight:600}.modal-field input,.modal-field select{color:#1e293b;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;outline:none;width:100%;padding:.6rem .85rem;font-size:.9rem;transition:border-color .18s,box-shadow .18s,background .18s}.modal-field input:focus,.modal-field select:focus{background:#fff;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601a}.modal-field input:disabled{color:#64748b;cursor:not-allowed;background:#f1f5f9}.modal-error{color:#ef4444;background:#fff5f5;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:.35rem;margin:0;padding:.5rem .75rem;font-size:.8rem;font-weight:500;display:flex}.modal-error svg{flex-shrink:0;width:14px;height:14px}.modal-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.25rem;display:flex}.btn-cancelar{color:#64748b;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:9px;padding:.6rem 1.2rem;font-size:.875rem;font-weight:600;transition:background .15s,border-color .15s}.btn-cancelar:hover{background:#f8fafc;border-color:#cbd5e1}.btn-guardar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0f3460,#533483);border:none;border-radius:9px;padding:.6rem 1.4rem;font-size:.875rem;font-weight:600;transition:opacity .15s,transform .12s;box-shadow:0 3px 10px #0f34604d}.btn-guardar:hover{opacity:.9;transform:translateY(-1px)}.btn-guardar:active{transform:translateY(0)}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=768px){.catalogo-view{padding:1.25rem .85rem}.catalogo-header{flex-direction:column;align-items:stretch;gap:.85rem;margin-bottom:1.25rem}.btn-agregar{justify-content:center;width:100%}.catalogo-toolbar{gap:.5rem;padding:.85rem}.search-wrapper{max-width:100%}.materiales-table,.materiales-table tbody{display:block}.materiales-table thead{display:none}.materiales-table tbody tr{border-bottom:1px solid #f1f5f9;grid-template-columns:1fr auto;grid-template-areas:"codigo acciones""desc acciones""unidad precio";gap:.25rem .5rem;padding:.85rem 1rem;display:grid}.materiales-table tbody tr:last-child{border-bottom:none}.materiales-table tbody tr:hover td{background:0 0}.materiales-table td{border:none;align-items:center;padding:0;font-size:.875rem;display:flex}.materiales-table td[data-label=Código]{grid-area:codigo;font-size:.72rem}.materiales-table td[data-label=Descripción]{color:#1e293b;grid-area:desc;font-size:.9rem;font-weight:600}.materiales-table td[data-label=Unidad]{grid-area:unidad;margin-top:.25rem}.materiales-table td[data-label=Precio]{color:#0f3460;grid-area:precio;justify-content:flex-end;margin-top:.25rem;font-weight:700}.materiales-table td.cell-acciones{border-left:1px solid #f1f5f9;flex-direction:column;grid-area:acciones;justify-content:center;gap:.35rem;padding-left:.5rem}.materiales-table .btn-accion{border-radius:9px;width:36px;height:36px}.materiales-table .btn-accion svg{width:16px;height:16px}.modal-row{flex-direction:column}.modal-footer{flex-direction:column-reverse}.btn-cancelar,.btn-guardar{text-align:center;justify-content:center;width:100%}}.presup-view{max-width:1100px;padding:2rem 2.25rem}.presup-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;display:flex}.presup-page-header h1{color:#1e293b;letter-spacing:-.4px;margin:0 0 .3rem;font-size:1.6rem;font-weight:700}.presup-page-header>div>p,.form-breadcrumb>div>p{color:#64748b;margin:0;font-size:.9rem}.btn-primario{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#0f3460,#533483);border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;transition:opacity .18s,transform .15s,box-shadow .18s;display:inline-flex;box-shadow:0 4px 14px #0f346059}.btn-primario:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 18px #0f346066}.btn-primario:active{transform:translateY(0)}.btn-primario svg{flex-shrink:0;width:17px;height:17px}.btn-secundario{color:#1e293b;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;align-items:center;gap:.5rem;padding:.65rem 1.1rem;font-size:.9rem;font-weight:600;transition:background .15s,border-color .15s,transform .12s;display:inline-flex}.btn-secundario:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.btn-secundario:active{transform:translateY(0)}.btn-secundario svg{flex-shrink:0;width:17px;height:17px}.btn-lg{padding:.75rem 1.5rem;font-size:.95rem}.presup-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #00000012,0 4px 16px #0000000f}.presup-card-title{border-bottom:1px solid #f1f5f9;padding:1.25rem 1.5rem 1rem}.presup-card-title h2{color:#1e293b;margin:0;font-size:1rem;font-weight:700}.presup-table-wrapper{overflow-x:auto}.presup-table{border-collapse:collapse;width:100%;font-size:.875rem}.presup-table thead tr{background:#f8fafc}.presup-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:.75rem 1.25rem;font-size:.72rem;font-weight:700}.presup-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.9rem 1.25rem}.presup-table tbody tr:last-child td{border-bottom:none}.presup-table tbody tr:hover td{background:#f8fafc}.cell-mono{font-family:ui-monospace,Consolas,monospace;font-size:.8rem;font-weight:600;color:#64748b!important}.cell-bold{font-weight:600;color:#1e293b!important}.cell-muted{font-size:.85rem;color:#64748b!important}.cell-precio{white-space:nowrap;font-weight:700;color:#0f3460!important}.badge{white-space:nowrap;border-radius:999px;align-items:center;padding:.25rem .7rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-presup{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.badge-venta{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.cell-acciones{white-space:nowrap}.btn-accion{cursor:pointer;border:none;border-radius:7px;justify-content:center;align-items:center;width:30px;height:30px;transition:background .15s,transform .12s;display:inline-flex}.btn-accion svg{width:14px;height:14px}.btn-accion:active{transform:scale(.93)}.btn-pdf{color:#1d4ed8;background:#eff6ff;margin-right:.35rem}.btn-pdf:hover{background:#dbeafe}.btn-aprobar{color:#15803d;background:#f0fdf4;margin-right:.35rem}.btn-aprobar:hover:not(:disabled){background:#dcfce7}.btn-aprobar:disabled{opacity:.3;cursor:not-allowed}.btn-editar{color:#a16207;background:#fefce8;margin-right:.35rem}.btn-editar:hover{background:#fef9c3}.btn-eliminar{color:#dc2626;background:#fff5f5}.btn-eliminar:hover{background:#fee2e2}.form-breadcrumb{flex-direction:column;gap:.6rem;display:flex}.btn-volver{color:#64748b;cursor:pointer;background:0 0;border:none;align-items:center;gap:.3rem;padding:0;font-size:.82rem;font-weight:600;transition:color .15s;display:inline-flex}.btn-volver:hover{color:#0f3460}.btn-volver svg{width:16px;height:16px}.form-acciones-top{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.form-grid{flex-direction:column;gap:1.25rem;display:flex}.form-seccion{padding:1.5rem;overflow:visible}.seccion-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.seccion-header-row .seccion-titulo{margin-bottom:0}.seccion-header-row .btn-add-fila{margin-top:0}.seccion-titulo{color:#1e293b;align-items:center;gap:.5rem;margin:0 0 1.25rem;font-size:.95rem;font-weight:700;display:flex}.seccion-titulo svg{color:#533483;flex-shrink:0;width:18px;height:18px}.campos-fila{flex-wrap:wrap;gap:1rem;display:flex}.campo-grupo{flex-direction:column;flex:1;gap:.35rem;min-width:180px;display:flex}.campo-chico{flex:0 0 160px;min-width:140px}.campo-grupo label{color:#374151;font-size:.8rem;font-weight:600}.campo-grupo input{color:#1e293b;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;outline:none;padding:.6rem .85rem;font-size:.9rem;transition:border-color .18s,box-shadow .18s,background .18s}.campo-grupo input:focus{background:#fff;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601a}.input-textarea{color:#1e293b;resize:vertical;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;outline:none;width:100%;padding:.6rem .85rem;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .18s,box-shadow .18s,background .18s}.input-textarea:focus{background:#fff;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601a}.input-readonly{cursor:not-allowed;font-family:ui-monospace,Consolas,monospace;font-weight:600;color:#64748b!important;background:#f1f5f9!important}.form-tabla{border-collapse:collapse;width:100%;margin-bottom:.75rem;font-size:.875rem}.form-tabla thead tr{background:#f8fafc}.form-tabla th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;padding:.6rem .75rem;font-size:.7rem;font-weight:700}.form-tabla td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.5rem}.form-tabla tbody tr:last-child td{border-bottom:none}.col-num{text-align:right;width:140px}.col-unidad{width:110px}.col-ico{width:38px}.select-unidad{color:#1e293b;appearance:none;cursor:pointer;box-sizing:border-box;background:#f8fafc url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCAyNCAyNCIgc3Ryb2tlLXdpZHRoPSIyLjIiIHN0cm9rZT0iIzljYTNhZiI+PHBvbHlsaW5lIHBvaW50cz0iNiA5IDEyIDE1IDE4IDkiLz48L3N2Zz4=) right .5rem center/.7rem no-repeat;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:.5rem 2rem .5rem .65rem;font-size:.8rem;transition:border-color .18s,box-shadow .18s}.select-unidad:focus{background-color:#fff;border-color:#0f3460;box-shadow:0 0 0 3px #0f346014}.input-tabla{color:#1e293b;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:.5rem .65rem;font-size:.875rem;transition:border-color .18s,box-shadow .18s}.input-tabla:focus{background:#fff;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601a}.input-num{text-align:right;font-variant-numeric:tabular-nums}.input-prefix-wrap{align-items:center;display:flex;position:relative}.input-prefix{color:#94a3b8;pointer-events:none;font-size:.875rem;position:absolute;left:.65rem}.input-prefix-wrap .input-num{padding-left:1.4rem}.select-tabla{appearance:none;cursor:pointer}.cell-readonly{text-align:right;white-space:nowrap;font-size:.8rem;color:#94a3b8!important;padding-right:.75rem!important}.cell-subtotal{text-align:right;white-space:nowrap;font-weight:700;color:#0f3460!important;padding-right:.5rem!important}.btn-quitar{color:#dc2626;cursor:pointer;background:#fff5f5;border:none;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,transform .12s;display:flex}.btn-quitar:hover:not(:disabled){background:#fee2e2}.btn-quitar:active{transform:scale(.92)}.btn-quitar:disabled{opacity:.35;cursor:not-allowed}.btn-quitar svg{width:14px;height:14px}.btn-add-fila{color:#64748b;cursor:pointer;background:0 0;border:1.5px dashed #cbd5e1;border-radius:8px;align-items:center;gap:.4rem;margin-top:.25rem;padding:.4rem .85rem;font-size:.82rem;font-weight:600;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.btn-add-fila:hover{color:#533483;background:#5334830a;border-color:#533483}.btn-add-fila svg{width:14px;height:14px}.totales-card{background:#fff}.totales-lista{flex-direction:column;gap:.65rem;max-width:400px;margin-bottom:1.5rem;display:flex}.total-fila{color:#475569;justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.total-fila span:last-child{color:#1e293b;font-variant-numeric:tabular-nums;font-weight:600}.total-divisor{border:none;border-top:1.5px solid #e2e8f0;margin:.25rem 0}.total-grande{font-weight:700;color:#1e293b!important;font-size:1.15rem!important}.total-grande span:last-child{font-size:1.3rem;color:#0f3460!important}.form-acciones-bottom{flex-wrap:wrap;gap:.75rem;display:flex}.form-empty-state{text-align:center;color:#94a3b8;background:#f8fafc;border:1.5px dashed #e2e8f0;border-radius:10px;margin:.5rem 0 .25rem;padding:1.25rem 1rem;font-size:.875rem;line-height:1.6}.form-empty-state strong{color:#64748b;font-weight:600}@media (width<=768px){.presup-view{padding:1.25rem .85rem}.presup-page-header{margin-bottom:1.25rem}.presup-page-header h1{font-size:1.25rem}.btn-primario{justify-content:center;width:100%}.presup-page-header{flex-direction:column;align-items:stretch}.form-acciones-top{flex-direction:column}.form-acciones-top .btn-secundario,.form-acciones-top .btn-primario{justify-content:center;width:100%}.presup-table,.presup-table tbody{display:block}.presup-table thead{display:none}.presup-table tbody tr{border-bottom:1px solid #f1f5f9;grid-template-columns:1fr auto;grid-template-areas:"folio estado""cliente cliente""fecha precio""acc acc";gap:.25rem .5rem;padding:.9rem 1rem;display:grid}.presup-table tbody tr:last-child{border-bottom:none}.presup-table tbody tr:hover td{background:0 0}.presup-table td{border:none;align-items:center;padding:0;font-size:.875rem;display:flex}.presup-table td[data-label=Folio]{grid-area:folio;font-size:.72rem}.presup-table td[data-label=Estado]{grid-area:estado;justify-content:flex-end}.presup-table td[data-label=Cliente]{color:#1e293b;grid-area:cliente;font-size:.9rem;font-weight:600}.presup-table td[data-label=Fecha]{color:#64748b;grid-area:fecha;margin-top:.1rem;font-size:.8rem}.presup-table td[data-label=Total]{color:#0f3460;grid-area:precio;justify-content:flex-end;margin-top:.1rem;font-size:.95rem;font-weight:700}.presup-table td.cell-acciones{border-top:1px solid #f1f5f9;grid-area:acc;gap:.4rem;margin-top:.4rem;padding-top:.65rem}.presup-table .btn-accion{border-radius:9px;width:36px;height:36px}.presup-table .btn-accion svg{width:16px;height:16px}.form-seccion{padding:1rem}.campos-fila{flex-direction:column}.campo-chico{flex:unset;width:100%}.form-tabla,.form-tabla tbody{display:block}.form-tabla thead{display:none}.form-tabla tbody tr{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;grid-template-columns:1fr 1fr auto;grid-template-areas:"desc desc del""cant pu pu""sub sub sub";gap:.4rem .5rem;margin-bottom:.5rem;padding:.85rem;display:grid;border-bottom:1.5px solid #e2e8f0!important}.form-tabla tbody tr:last-child{margin-bottom:0}.form-tabla td{padding:0;display:block;border:none!important}.form-tabla td:first-child{grid-area:desc}.form-tabla td:nth-child(2){grid-area:cant}.form-tabla td:nth-child(3){grid-area:pu}.form-tabla td:nth-child(4){grid-area:sub;justify-content:space-between;align-items:center;font-size:.875rem;display:flex;border-top:1px dashed #e2e8f0!important;padding-top:.4rem!important}.form-tabla td:nth-child(4):before{content:"Subtotal:";color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;font-size:.72rem;font-weight:700}.form-tabla td:nth-child(5){grid-area:del;justify-content:flex-end;align-items:flex-start;display:flex}.btn-quitar{border-radius:9px;width:34px;height:34px}.btn-quitar svg{width:16px;height:16px}.input-tabla{padding:.65rem;font-size:.9rem}.totales-lista{max-width:100%}.form-acciones-bottom{flex-direction:column}.form-acciones-bottom .btn-secundario,.form-acciones-bottom .btn-primario{justify-content:center;width:100%}}.autocomplete-wrap{position:relative}.autocomplete-input{color:#1e293b;box-sizing:border-box;background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.autocomplete-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61f}.autocomplete-input.autocomplete-selected{background:#f0fdf4;border-color:#22c55e}.autocomplete-input:disabled{color:#94a3b8;cursor:not-allowed;background:#f8fafc}.autocomplete-list{z-index:100;background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;max-height:220px;margin:0;padding:.25rem 0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001a}.autocomplete-item{cursor:pointer;align-items:baseline;gap:.5rem;padding:.55rem .9rem;transition:background .1s;display:flex}.autocomplete-item:hover,.autocomplete-item--active{background:#eff6ff}.autocomplete-nombre{color:#1e293b;font-size:.9rem;font-weight:500}.autocomplete-sub{color:#94a3b8;font-size:.78rem}.autocomplete-empty{color:#94a3b8;padding:.65rem .9rem;font-size:.85rem;font-style:italic}.api-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:.4rem;padding:.5rem .75rem;font-size:.85rem}.svc-autocomplete{align-items:center;display:flex;position:relative}.svc-autocomplete .input-tabla{flex:1;padding-right:3.2rem}.svc-btn-group{align-items:center;gap:.1rem;display:flex;position:absolute;right:.3rem}.svc-icon-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;transition:color .15s,background .15s;display:flex}.svc-icon-btn svg{pointer-events:none;width:13px;height:13px}.svc-icon-btn:hover{color:#374151;background:#f1f5f9}.svc-toggle-btn.active{color:#3b82f6;background:#eff6ff;transform:rotate(180deg)}.svc-dropdown{z-index:200;background:#fff;border:1.5px solid #e2e8f0;border-radius:.5rem;max-height:220px;margin:0;padding:.25rem 0;list-style:none;position:absolute;top:calc(100% + 3px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001a}.svc-dropdown-item{cursor:pointer;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem .85rem;transition:background .1s;display:flex}.svc-dropdown-item:hover{background:#eff6ff}.svc-dropdown-nombre{color:#1e293b;font-size:.875rem;font-weight:500}.svc-dropdown-precio{color:#64748b;white-space:nowrap;flex-shrink:0;font-size:.78rem;font-weight:500}.svc-dropdown-empty{color:#94a3b8;padding:.6rem .85rem;font-size:.82rem;font-style:italic}
