:root{--navy: #0c1a2e;--navy-2: #13243b;--navy-3: #1b2f48;--cyan: #22b8d8;--cyan-strong: #17a6c6;--cyan-soft: #e6f7fb;--bg: #f4f7fa;--surface: #ffffff;--surface-2: #f8fafc;--border: #e3e9f1;--border-2: #eef2f7;--text: #11243c;--text-soft: #3f5670;--muted: #7387a0;--sidebar-text: #c3d2e3;--sidebar-muted: #6a7d96;--shadow-sm: 0 1px 2px rgba(16, 36, 60, .06), 0 1px 3px rgba(16, 36, 60, .05);--shadow-md: 0 4px 16px rgba(16, 36, 60, .08);--shadow-lg: 0 18px 50px rgba(12, 26, 46, .18);--radius: 12px}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}h1,h2,h3{color:var(--text)}h2{margin-top:0}h2,h3{font-weight:700;letter-spacing:-.01em}.muted{color:var(--muted)}.small{font-size:.85rem}pre{background:var(--surface-2);border:1px solid var(--border);padding:1rem;border-radius:8px;overflow-x:auto;font-size:.85rem;color:var(--text-soft)}.centered{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--navy);color:var(--sidebar-text);padding:1.5rem .9rem;display:flex;flex-direction:column;gap:1.5rem}.sidebar-brand{display:flex;align-items:center;gap:.7rem;padding:.25rem .5rem .5rem}.sidebar-logo{width:40px;height:40px;flex:0 0 auto}.sidebar-brand-text{display:flex;flex-direction:column;line-height:1.1}.sidebar-brand-name{font-weight:700;font-size:1.35rem;color:#fff;letter-spacing:-.01em}.sidebar-brand-sub{font-size:.7rem;font-weight:700;letter-spacing:.22em;color:var(--cyan);margin-top:2px}.sidebar nav{display:flex;flex-direction:column;gap:.2rem}.sidebar nav a{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--sidebar-text);padding:.6rem .75rem;border-radius:9px;font-size:.92rem;font-weight:500;border-left:3px solid transparent;transition:background .15s,color .15s}.sidebar nav a svg{width:18px;height:18px;flex:0 0 auto;opacity:.85}.sidebar nav a:hover{background:var(--navy-2);color:#fff}.sidebar nav a.active{background:var(--navy-2);color:#fff;border-left-color:var(--cyan)}.sidebar nav a.active svg{color:var(--cyan);opacity:1}.layout-main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:center;padding:.9rem 2rem;border-bottom:1px solid var(--border);background:var(--surface)}.topbar-right{display:flex;align-items:center;gap:1rem;font-size:.9rem}.layout-main main{padding:2rem;flex:1;overflow-y:auto}button{cursor:pointer;background:var(--cyan);color:#fff;border:none;padding:.55rem .95rem;border-radius:8px;font:inherit;font-size:.875rem;font-weight:600;transition:background .15s,box-shadow .15s}button:hover:not(:disabled){background:var(--cyan-strong)}button:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text-soft);border:1px solid var(--border);font-weight:500}.btn-secondary:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-danger{background:#e0392b}.btn-danger:hover:not(:disabled){background:#c32a1f}.btn-link{background:transparent;color:var(--cyan-strong);padding:0;font-size:.875rem;font-weight:600}.btn-link:hover:not(:disabled){background:transparent;text-decoration:underline}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:1rem;background:radial-gradient(1200px 600px at 50% -10%,#16304d 0%,transparent 60%),var(--navy)}.login-card{background:var(--surface);padding:2.25rem 2rem;border-radius:16px;width:100%;max-width:390px;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow-lg)}.login-brand{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:.25rem}.login-brand img{width:56px;height:56px}.login-brand .login-name{font-size:1.6rem;font-weight:700;color:var(--text)}.login-brand .login-sub{font-size:.72rem;font-weight:700;letter-spacing:.22em;color:var(--cyan-strong)}.login-card h1{margin:0;font-size:1.4rem;text-align:center}.login-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;color:var(--text-soft);font-weight:500}input,select,textarea{font:inherit;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.9rem}input::placeholder,textarea::placeholder{color:#a9b6c6}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px #22b8d826}.error-box{background:#fdecec;color:#b42318;border:1px solid #f7cfca;padding:.55rem .75rem;border-radius:8px;font-size:.875rem;margin:.5rem 0}.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.tab{background:transparent;color:var(--muted);border-radius:0;border-bottom:2px solid transparent;padding:.625rem 1rem;font-weight:600}.tab:hover:not(:disabled){background:transparent;color:var(--text)}.tab-active{color:var(--cyan-strong);border-bottom-color:var(--cyan)}.tab-content{padding-top:.5rem}.tab-contador{display:inline-block;margin-left:.4rem;padding:0 .4rem;border-radius:999px;background:var(--border);color:var(--text-soft);font-size:.7rem;font-weight:700}.tab-active .tab-contador{background:var(--cyan);color:#fff}.catalogo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.catalogo-header h3{margin:0}.inline-form{display:flex;flex-wrap:wrap;gap:.5rem;background:var(--surface);border:1px solid var(--border);padding:1rem;border-radius:var(--radius);margin-bottom:1rem;align-items:center;box-shadow:var(--shadow-sm)}.inline-form input,.inline-form select{flex:1;min-width:160px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;background:var(--surface);border:1px solid var(--border);padding:1.25rem;border-radius:var(--radius);margin-bottom:1rem;box-shadow:var(--shadow-sm)}.campo{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:var(--text-soft);font-weight:500}.campo span em{font-style:normal;margin-left:.25rem;color:var(--muted)}.form-actions{grid-column:1 / -1;display:flex;gap:.5rem;justify-content:flex-end}.data-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table th,.data-table td{text-align:left;padding:.7rem .95rem;border-bottom:1px solid var(--border-2);font-size:.9rem}.data-table th{background:var(--surface-2);color:var(--muted);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#f3f8fb}.fila-inactiva td{color:#9aa8ba;font-style:italic}.badge{display:inline-block;padding:.22rem .65rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.3px;white-space:nowrap}.estado-amarillo{background:#fef3c7;color:#92400e}.estado-azul{background:#dbeafe;color:#1e40af}.estado-violeta{background:#ede9fe;color:#6b21a8}.estado-verde{background:#dcfce7;color:#15803d}.estado-gris{background:#e8edf3;color:#51637a}.estado-rojo{background:#fde2e0;color:#b42318}.badge-alerta{margin-left:.6rem;animation:pulso-alerta 1.6s ease-in-out infinite}@keyframes pulso-alerta{0%,to{box-shadow:0 0 #e0392b8c}50%{box-shadow:0 0 0 6px #e0392b00}}.fila-nueva td{background:#e0392b1a!important;animation:pulso-fila 1.8s ease-in-out infinite}@keyframes pulso-fila{0%,to{background:#e0392b12!important}50%{background:#e0392b29!important}}input[readonly]{background:var(--surface-2);color:var(--muted);cursor:not-allowed}.fila-clicable{cursor:pointer}.fila-clicable:hover td{background:#f3f8fb}.detalle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin:1.5rem 0}.tarjeta{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm)}.tarjeta h4{margin:0 0 .875rem;color:var(--cyan-strong);font-size:.78rem;text-transform:uppercase;letter-spacing:.6px;font-weight:700}.kv{display:flex;justify-content:space-between;gap:1rem;padding:.4rem 0;font-size:.9rem;border-bottom:1px solid var(--border-2)}.kv:last-child{border-bottom:none}.kv>span{color:var(--muted)}.kv>strong{color:var(--text);text-align:right}.kv-total>strong{color:var(--cyan-strong);font-size:1.05rem}.fase{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-top:1.5rem;box-shadow:var(--shadow-sm)}.fase-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.fase-header h3{margin:0;color:var(--text);font-size:1.1rem}.upload-box{display:flex;flex-direction:column;gap:.75rem}.upload-box-empty{padding:1.5rem;border:1px dashed #c2cedd;border-radius:8px;text-align:center;color:var(--muted)}.upload-info{font-size:.9rem}.upload-actions{display:flex;gap:.5rem;flex-wrap:wrap}.preview-img{max-width:100%;max-height:320px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);object-fit:contain}.preview-pdf{width:100%;height:320px;background:var(--surface-2);border-radius:8px;border:1px solid var(--border)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c1a2e73;display:grid;place-items:center;z-index:1000;padding:1rem}.modal{background:var(--surface);border-radius:14px;width:100%;max-width:480px;box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;color:var(--text);font-size:1.1rem}.modal-body{padding:1.25rem}.modal-actions{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:2000;max-width:360px}.toast{padding:.75rem 1rem;border-radius:10px;font-size:.9rem;color:#fff;cursor:pointer;box-shadow:var(--shadow-md);animation:toast-in .18s ease-out}.toast-exito{background:#16a34a}.toast-error{background:#e0392b}.toast-info{background:var(--cyan-strong)}@keyframes toast-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.bitacora-filtros{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.25rem}.bitacora-filtros label{display:flex;flex-direction:column;gap:.25rem}.bitacora-filtros select,.bitacora-filtros input{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.4rem .55rem;font-size:.85rem}.bitacora-timeline{list-style:none;margin:0;padding:0}.bitacora-item{position:relative;display:flex;gap:.85rem;padding:0 0 1.1rem}.bitacora-item:not(:last-child):before{content:"";position:absolute;left:6px;top:16px;bottom:0;width:2px;background:var(--border)}.bitacora-punto{position:relative;z-index:1;flex:0 0 auto;width:14px;height:14px;margin-top:3px;border-radius:50%;border:2px solid var(--surface);box-shadow:0 0 0 1px var(--border)}.bitacora-cuerpo{flex:1;min-width:0}.bitacora-cabecera{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.bitacora-detalle{margin:.4rem 0 .2rem;color:var(--text-soft);font-size:.9rem}.bitacora-detalle code{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:.05rem .35rem;font-size:.82rem}.bitacora-campos{margin:.4rem 0 .2rem;padding-left:1.1rem;color:var(--text-soft);font-size:.85rem}.bitacora-meta{margin:.3rem 0 0}.bitacora-comentario{margin:.4rem 0 0;padding:.4rem .6rem;background:var(--cyan-soft);border-left:2px solid var(--cyan);border-radius:4px;font-size:.85rem;color:var(--text)}.campana-wrap{position:relative;display:inline-flex}.campana-btn{position:relative;background:transparent;color:var(--text-soft);padding:.25rem .45rem;font-size:1.2rem;line-height:1}.campana-btn:hover:not(:disabled){background:var(--surface-2)}.campana-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#e0392b;color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center}.campana-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1500}.bandeja{position:absolute;top:calc(100% + 8px);right:0;width:340px;max-width:90vw;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);z-index:1600;overflow:hidden}.bandeja-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.bandeja-lista{max-height:380px;overflow-y:auto}.bandeja-footer{padding:.6rem 1rem;border-top:1px solid var(--border);text-align:center}.diag-leyenda{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;margin-bottom:.75rem;padding:.5rem .75rem;border:1px dashed var(--border);border-radius:8px}.diag-cliente{border:1px solid var(--border);border-radius:12px;margin-bottom:.6rem;overflow:hidden;transition:border-color .15s ease}.diag-cliente:hover,.diag-cliente-abierto{border-color:#22d3ee73}.diag-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;width:100%;padding:.75rem 1rem;background:transparent;border:0;cursor:pointer;text-align:left;color:inherit;font:inherit;flex-wrap:wrap}.diag-header-izq{flex:1 1 240px;min-width:0}.diag-nombre{font-weight:700;font-size:.95rem;line-height:1.25;margin-bottom:.15rem}.diag-header-der{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;flex:0 1 auto;min-width:220px}.diag-header-total{display:flex;align-items:center;gap:.5rem;font-size:1.1rem}.diag-flecha{color:var(--muted);font-size:.85rem;transition:transform .15s ease}.diag-flecha-abierta{transform:rotate(90deg)}.diag-minibar{display:flex;width:220px;height:6px;border-radius:4px;overflow:hidden;background:#94a3b826}.diag-chips{display:inline-flex;gap:.7rem;flex-wrap:wrap;font-variant-numeric:tabular-nums;font-size:.8rem}.diag-chip{display:inline-flex;align-items:center;gap:.3rem;white-space:nowrap}.diag-dot{width:8px;height:8px;border-radius:50%;flex:none}.diag-cero{color:var(--muted);font-size:.8rem}.diag-cuerpo{border-top:1px solid var(--border);padding:.75rem 1rem .9rem;display:flex;flex-direction:column;gap:.75rem;background:#94a3b80a}.diag-rama-titulo{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}.diag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.6rem;align-items:start}.diag-caja{border:1px solid var(--border);border-radius:10px;padding:.55rem .7rem;display:flex;flex-direction:column;gap:.3rem}.diag-caja-fila{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem}.diag-caja-nombre{font-weight:600;font-size:.83rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.diag-caja-total{font-variant-numeric:tabular-nums;font-size:.85rem;white-space:nowrap}.diag-caja-cliente{border-left:4px solid #22d3ee;max-width:560px}.diag-caja-un{border-left:4px solid #818cf8}.diag-caja-suc{border-left:4px solid #34d399}.diag-un-wrap{display:flex;flex-direction:column;gap:.35rem}.diag-sucursales{margin-left:.9rem;padding-left:.7rem;border-left:2px dashed var(--border);display:flex;flex-direction:column;gap:.35rem}.diag-cero-grupo summary{cursor:pointer;color:var(--muted);font-size:.8rem}.diag-cero-lista{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.diag-tag{border:1px solid var(--border);border-radius:999px;padding:.15rem .6rem;font-size:.75rem;white-space:nowrap}@media (max-width: 640px){.diag-header-der{align-items:flex-start;min-width:0}.diag-minibar{width:100%}}.bandeja-vacia{padding:1.25rem 1rem;text-align:center;color:var(--muted)}.notif-item{display:flex;flex-direction:column;gap:.15rem;width:100%;text-align:left;background:transparent;color:var(--text);border-radius:0;border-bottom:1px solid var(--border-2);padding:.7rem 1rem}.notif-item:hover:not(:disabled){background:var(--surface-2)}.notif-no-leida{background:var(--cyan-soft)}.notif-no-leida:hover:not(:disabled){background:#d8f1f7}.notif-no-leida .notif-titulo:before{content:"";display:inline-block;width:7px;height:7px;margin-right:6px;border-radius:50%;background:var(--cyan);vertical-align:middle}.notif-titulo{color:var(--text);font-size:.85rem;font-weight:600}.notif-mensaje{color:var(--text-soft);font-size:.8rem}.notif-fecha{font-size:.72rem;color:var(--muted)}.topbar-left{display:flex;align-items:center;gap:.75rem}.btn-hamburguesa{display:none;background:transparent;color:var(--text-soft);font-size:1.3rem;line-height:1;padding:.25rem .5rem}.btn-hamburguesa:hover:not(:disabled){background:var(--surface-2)}.sidebar-backdrop{display:none}@media (max-width: 1024px){.btn-hamburguesa{display:inline-flex}.sidebar{position:fixed;top:0;bottom:0;left:0;z-index:1700;transform:translate(-100%);transition:transform .2s ease}.sidebar-abierta{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0c1a2e80;z-index:1650}.topbar{padding:.75rem 1rem}.layout-main main{padding:1.5rem}}@media (max-width: 640px){.layout-main main{padding:1rem}.topbar-usuario{display:none}.topbar-right{gap:.5rem}.data-table{display:block;overflow-x:auto;white-space:nowrap}.tabs{overflow-x:auto;flex-wrap:nowrap}.tab{white-space:nowrap}.bandeja{position:fixed;left:.5rem;right:.5rem;width:auto}.catalogo-header{flex-direction:column;align-items:flex-start;gap:.5rem}.bitacora-filtros{gap:.6rem}}
