/* ===== UI compartida de la app (botones, tablas, forms, badges) ===== */

/* Botones */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-ui);font-size:13.5px;font-weight:700;
  padding:11px 18px;border-radius:var(--r-md);
  transition:.18s ease;white-space:nowrap;line-height:1;
}
.btn svg{width:17px;height:17px}
.btn.primary{background:var(--grad-cy);color:#fff;box-shadow:0 10px 22px rgba(11,126,243,.28)}
.btn.primary:hover{transform:translateY(-2px)}
.btn.ghost{background:var(--surface);color:var(--primary);border:1px solid var(--border);box-shadow:var(--sh)}
.btn.ghost:hover{background:var(--bg)}
.btn.sm{padding:8px 13px;font-size:12.5px;border-radius:10px}
.btn.danger{background:rgba(229,72,77,.1);color:var(--danger)}
.btn.danger:hover{background:rgba(229,72,77,.16)}

/* Encabezado de página con acción a la derecha */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.toolbar h3{font-family:var(--font-display);font-size:16px;font-weight:600}
.toolbar .sub{color:var(--text-muted);font-size:12px;margin-top:2px}

/* Tabla */
.table-wrap{overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{
  text-align:left;font-weight:600;color:var(--text-muted);font-size:11.5px;
  text-transform:uppercase;letter-spacing:.05em;
  padding:0 14px 12px;border-bottom:1px solid var(--border);
}
.table td{padding:14px;border-bottom:1px solid var(--border);vertical-align:middle}
.table tbody tr{transition:.15s ease}
.table tbody tr:hover{background:var(--bg)}
.table tbody tr:last-child td{border-bottom:none}
.table .strong{font-weight:600;color:var(--text-main)}
.table .muted{color:var(--text-muted)}
.table a.row-link{color:var(--accent-dark);font-weight:600}
.cell-ico{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted)}
.cell-ico svg{width:14px;height:14px;flex-shrink:0}

/* Avatar de iniciales en celdas */
.ini{
  width:34px;height:34px;border-radius:11px;flex-shrink:0;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:13px;
  background:var(--accent-light);color:var(--accent-dark);
}
.name-cell{display:flex;align-items:center;gap:11px}

/* Badges (tipo / etapa) */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;padding:5px 11px;border-radius:999px;
}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.lead{color:var(--blue);background:rgba(11,126,243,.1)}
.badge.cliente{color:var(--success);background:rgba(20,184,122,.1)}
.badge.proveedor{color:var(--warning);background:rgba(245,165,36,.12)}
.badge.plain{color:var(--text-muted);background:var(--bg)}
.badge.plain::before{display:none}
.badge.on{color:var(--success);background:rgba(20,184,122,.1)}
.badge.off{color:var(--text-muted);background:var(--bg)}
.badge.off::before{display:none}

/* Estado vacío */
.empty{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:54px 24px;color:var(--text-muted);
}
.empty .ico{
  width:60px;height:60px;border-radius:18px;display:grid;place-items:center;margin-bottom:16px;
  background:var(--accent-light);color:var(--accent-dark);
}
.empty .ico svg{width:28px;height:28px}
.empty h4{font-family:var(--font-display);font-size:17px;color:var(--text-main);margin-bottom:6px}
.empty p{font-size:13.5px;max-width:340px;margin-bottom:18px}

/* Formularios */
.form{display:grid;gap:18px;max-width:620px}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12.5px;font-weight:600;color:var(--text-main)}
.field .hint{font-size:11.5px;color:var(--text-light)}
.input,.select,.textarea{
  font-family:var(--font-ui);font-size:14px;color:var(--text-main);
  background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);
  padding:12px 14px;outline:none;transition:.16s ease;width:100%;
}
.textarea{resize:vertical;min-height:96px}
.input:focus,.select:focus,.textarea:focus{
  border-color:var(--accent);background:var(--surface);
  box-shadow:0 0 0 4px var(--accent-light);
}
.form-actions{display:flex;gap:12px;align-items:center;margin-top:4px}

/* Alertas */
.alert{
  padding:13px 16px;border-radius:var(--r-md);font-size:13px;font-weight:500;margin-bottom:18px;
}
.alert.error{background:rgba(229,72,77,.1);color:var(--danger)}
.alert.ok{background:rgba(20,184,122,.1);color:var(--success)}

/* Barra "viendo cuenta como contador" */
.acting-bar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  background:var(--accent-dark);color:#fff;padding:10px 16px;border-radius:var(--r-md);margin-bottom:14px;
  font-size:13px;font-weight:500;
}
.acting-bar svg{width:16px;height:16px;vertical-align:-3px;margin-right:4px}
.acting-bar strong{font-weight:700}
.acting-bar .btn{background:rgba(255,255,255,.16);color:#fff;border-color:transparent}

/* Mini-tarjetas de totales (contabilidad) */
.cstat-row{display:flex;flex-wrap:wrap;gap:12px}
.cstat{flex:1 1 150px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px}
.cstat-main{background:var(--accent-light);border-color:transparent}
.cstat-label{color:var(--text-muted);font-size:12px;font-weight:500}
.cstat-value{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.02em;margin-top:2px}

/* Filas de usuario (admin de empresa) */
.user-row{border-top:1px solid var(--border);padding:14px 0}
.user-row:first-of-type{border-top:none}
.user-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.user-form{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px}
.user-form .input{flex:1;min-width:160px}
.user-form .select{min-width:120px}
.user-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}
.user-actions form{display:flex;gap:8px;margin:0}
.check{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text-muted);white-space:nowrap}
.check input{width:auto;margin:0}

/* Página "en construcción" */
.placeholder{display:flex;flex-direction:column;align-items:center;text-align:center;padding:64px 24px}
.placeholder .ph-ic{
  width:72px;height:72px;border-radius:20px;display:grid;place-items:center;margin-bottom:20px;
  background:var(--grad-cy);color:#fff;box-shadow:0 14px 30px rgba(11,126,243,.3);
}
.placeholder .ph-ic svg{width:34px;height:34px}
.placeholder h2{font-family:var(--font-display);font-size:24px;letter-spacing:-.02em;margin-bottom:10px}
.placeholder p{color:var(--text-muted);max-width:420px;margin-bottom:22px}

/* Link de volver */
.back-link{
  display:inline-flex;align-items:center;gap:7px;color:var(--text-muted);
  font-size:13px;font-weight:600;margin-bottom:16px;
}
.back-link svg{width:16px;height:16px}
.back-link:hover{color:var(--accent-dark)}

/* La grilla de módulos del dashboard, como link */
a.module{display:block;color:inherit}

/* Sub-navegación de módulo (tabs tipo pill) */
.subnav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.subnav a{
  display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:11px;
  font-size:13.5px;font-weight:600;color:var(--text-muted);
  background:var(--surface);border:1px solid var(--border);transition:.15s ease;
}
.subnav a svg{width:16px;height:16px}
.subnav a:hover{color:var(--accent-dark);border-color:var(--accent)}
.subnav a.active{
  background:var(--grad-cy);color:#fff;border-color:transparent;
  box-shadow:0 8px 18px rgba(11,126,243,.28);
}

/* Repetidor de insumos del producto */
.repeater .rep-row{
  display:grid;grid-template-columns:1fr 140px 42px;gap:10px;align-items:end;margin-bottom:10px;
}
.repeater .btn-x{
  width:42px;height:46px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);
  color:var(--danger);cursor:pointer;font-size:20px;line-height:1;
}
.repeater .btn-x:hover{background:rgba(229,72,77,.08);border-color:var(--danger)}

/* Preview en vivo de precio del producto */
.price-preview{
  display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 4px;
}
.price-preview > div{
  flex:1;min-width:120px;background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-md);padding:10px 14px;display:flex;flex-direction:column;gap:2px;
}
.price-preview .k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600}
.price-preview .v{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-main)}
.price-preview .hl{background:var(--grad-cy);border-color:transparent}
.price-preview .hl .k{color:rgba(255,255,255,.85)}
.price-preview .hl .v{color:#fff}

/* Métrica destacada (costo, stock, etc.) */
.metric{font-family:var(--font-display);font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--text-main)}
.metric small{font-size:14px;color:var(--text-muted);font-weight:600}

/* Pastilla de estado de orden / lote */
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:700}
.pill.pendiente{background:var(--bg);color:var(--text-muted)}
.pill.en_proceso{background:rgba(11,126,243,.12);color:var(--blue)}
.pill.completada,.pill.terminado{background:rgba(20,184,122,.12);color:var(--success)}
.pill.despachado{background:var(--bg);color:var(--text-light)}
.pill.borrador{background:rgba(245,165,36,.14);color:var(--warning)}
.pill.pagada{background:rgba(20,184,122,.12);color:var(--success)}

.pill.cerrada{background:rgba(20,184,122,.12);color:var(--success)}

/* Acciones agrupadas en una celda de tabla (editar/emitir/borrar) */
.row-actions{display:inline-flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}

/* Importaciones: filas de repeater con más columnas → layout flexible */
.repeater .imp-item,.repeater .imp-gasto,.repeater .imp-imp{
  display:flex;grid-template-columns:none;flex-wrap:wrap;gap:8px;align-items:center;
}
.repeater .imp-item > .input[name="item_nombre"],
.repeater .imp-gasto > .input[name="gasto_nombre"],
.repeater .imp-imp > .input[name="imp_nombre"]{flex:1;min-width:160px}
.upload-box{border:1px dashed var(--border);border-radius:var(--r-md);padding:14px;margin:4px 0 14px;background:var(--bg)}
.upload-box .form-actions{margin-top:8px}

@media (max-width:560px){
  .form .row2{grid-template-columns:1fr}
  .form .row3{grid-template-columns:1fr}
  .repeater .rep-row{grid-template-columns:1fr 88px 42px}
}

/* Campana de avisos + panel desplegable */
.bell-wrap{position:relative}
.bell-count{
  position:absolute;top:6px;right:7px;min-width:16px;height:16px;padding:0 4px;
  display:grid;place-items:center;border-radius:999px;
  background:var(--danger);color:#fff;font-size:10px;font-weight:700;line-height:1;
  border:2px solid var(--surface);
}
.avisos-panel{
  position:absolute;top:52px;right:0;width:340px;max-width:90vw;z-index:50;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);
  box-shadow:var(--sh-lg);overflow:hidden;
}
.avisos-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}
.avisos-leer{background:none;border:none;color:var(--accent-dark);font-size:12px;font-weight:600;cursor:pointer}
.avisos-list{max-height:380px;overflow-y:auto}
.avisos-item{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-bottom:1px solid var(--border);color:inherit}
.avisos-item:last-child{border-bottom:none}
.avisos-item:hover{background:var(--bg)}
.avisos-item.unread{background:var(--accent-light)}
.avisos-item .ai-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--bg);color:var(--accent-dark);flex-shrink:0}
.avisos-item .ai-ic svg{width:16px;height:16px}
.avisos-item .ai-t{font-size:13px;font-weight:600;color:var(--text-main)}
.avisos-item .ai-d{font-size:12px;color:var(--text-muted);margin-top:1px}
.avisos-group{padding:8px 14px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg)}
.avisos-empty{padding:22px 14px;text-align:center;color:var(--text-muted);font-size:13px}
